some documentation improvements

This commit is contained in:
Strong Liu 2011-10-30 22:14:59 +08:00
parent 653211da6c
commit dbbb3cb0d3
6 changed files with 47 additions and 36 deletions

View File

@ -71,7 +71,7 @@
<example> <example>
<title>Letting Hibernate find the mapping files for you</title> <title>Letting Hibernate find the mapping files for you</title>
<para> <para>
The <methodname>addConfig()</methodname> method directs Hibernate to search the CLASSPATH for the mapping The <methodname>addClass()</methodname> method directs Hibernate to search the CLASSPATH for the mapping
files, eliminating hard-coded file names. In the following example, it searches for files, eliminating hard-coded file names. In the following example, it searches for
<filename>org/hibernate/auction/Item.hbm.xml</filename> and <filename>org/hibernate/auction/Item.hbm.xml</filename> and
<filename>org/hibernate/auction/Bid.hbm.xml</filename>. <filename>org/hibernate/auction/Bid.hbm.xml</filename>.
@ -136,7 +136,7 @@
<title>c3p0 connection pool</title> <title>c3p0 connection pool</title>
<para> <para>
C3P0 is an open source JDBC connection pool distributed along with Hibernate in the <filename>lib/</filename> C3P0 is an open source JDBC connection pool distributed along with Hibernate in the <filename>lib/</filename>
directory. Hibernate uses its <classname>org.hibernate.connection.C3P0ConnectionProvider</classname> for directory. Hibernate uses its <classname>org.hibernate.service.jdbc.connections.internal.C3P0ConnectionProvider</classname> for
connection pooling if you set the <property>hibernate.c3p0.*</property> properties. properties. connection pooling if you set the <property>hibernate.c3p0.*</property> properties. properties.
</para> </para>
<itemizedlist> <itemizedlist>
@ -153,7 +153,7 @@
<para> <para>
Proxool is another open source JDBC connection pool distributed along with Hibernate in the Proxool is another open source JDBC connection pool distributed along with Hibernate in the
<filename>lib/</filename> directory. Hibernate uses its <filename>lib/</filename> directory. Hibernate uses its
<classname>org.hibernate.connection.ProxoolConnectionProvider</classname> for connection pooling if you set the <classname>org.hibernate.service.jdbc.connections.internal.ProxoolConnectionProvider</classname> for connection pooling if you set the
<property>hibernate.proxool.*</property> properties. Unlike c3p0, proxool requires some additional configuration <property>hibernate.proxool.*</property> properties. Unlike c3p0, proxool requires some additional configuration
parameters, as described by the Proxool documentation available at <ulink parameters, as described by the Proxool documentation available at <ulink
url="http://proxool.sourceforge.net/configure.html" />. url="http://proxool.sourceforge.net/configure.html" />.
@ -223,7 +223,7 @@
</para> </para>
<para> <para>
You can define your own plugin strategy for obtaining JDBC connections by implementing the interface 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 <interfacename>org.hibernate.service.jdbc.connections.spi.ConnectionProvider</interfacename> and specifying your custom
implementation with the <property>hibernate.connection.provider_class</property> property. implementation with the <property>hibernate.connection.provider_class</property> property.
</para> </para>
</section> </section>
@ -294,8 +294,12 @@
<entry>org.hibernate.dialect.IngresDialect</entry> <entry>org.hibernate.dialect.IngresDialect</entry>
</row> </row>
<row> <row>
<entry>Microsoft SQL Server</entry> <entry>Microsoft SQL Server 2005</entry>
<entry>org.hibernate.dialect.SQLServerDialect</entry> <entry>org.hibernate.dialect.SQLServer2005Dialect</entry>
</row>
<row>
<entry>Microsoft SQL Server 2008</entry>
<entry>org.hibernate.dialect.SQLServer2008Dialect</entry>
</row> </row>
<row> <row>
<entry>Mckoi SQL</entry> <entry>Mckoi SQL</entry>
@ -307,7 +311,7 @@
</row> </row>
<row> <row>
<entry>MySQL with InnoDB</entry> <entry>MySQL with InnoDB</entry>
<entry>org.hibernate.dialect.MySQLInnoDBDialect</entry> <entry>org.hibernate.dialect.MySQL5InnoDBDialect</entry>
</row> </row>
<row> <row>
<entry>MySQL with MyISAM</entry> <entry>MySQL with MyISAM</entry>
@ -342,8 +346,12 @@
<entry>org.hibernate.dialect.SAPDBDialect</entry> <entry>org.hibernate.dialect.SAPDBDialect</entry>
</row> </row>
<row> <row>
<entry>Sybase</entry> <entry>Sybase ASE 15.5</entry>
<entry>org.hibernate.dialect.SybaseDialect</entry> <entry>org.hibernate.dialect.SybaseASE15Dialect</entry>
</row>
<row>
<entry>Sybase ASE 15.7</entry>
<entry>org.hibernate.dialect.SybaseASE157Dialect</entry>
</row> </row>
<row> <row>
<entry>Sybase Anywhere</entry> <entry>Sybase Anywhere</entry>
@ -365,22 +373,22 @@
<section> <section>
<title>Dialect resolution</title> <title>Dialect resolution</title>
<para> <para>
Assuming a <interfacename>org.hibernate.connection.ConnectionProvider</interfacename> has been Assuming a <interfacename>org.hibernate.service.jdbc.connections.spi.ConnectionProvider</interfacename> has been
set up, Hibernate will attempt to automatically determine the Dialect to use based on the set up, Hibernate will attempt to automatically determine the Dialect to use based on the
<interfacename>java.sql.DatabaseMetaData</interfacename> reported by a <interfacename>java.sql.DatabaseMetaData</interfacename> reported by a
<interfacename>java.sql.Connection</interfacename> obtained from that <interfacename>java.sql.Connection</interfacename> obtained from that
<interfacename>org.hibernate.connection.ConnectionProvider</interfacename>. <interfacename>org.hibernate.service.jdbc.connections.spi.ConnectionProvider</interfacename>.
</para> </para>
<para> <para>
This functionality is provided by a series of This functionality is provided by a series of
<interfacename>org.hibernate.dialect.resolver.DialectResolver</interfacename> instances registered <interfacename>org.hibernate.service.jdbc.dialect.spi.DialectResolver</interfacename> instances registered
with Hibernate internally. Hibernate comes with a standard set of recognitions. If your application with Hibernate internally. Hibernate comes with a standard set of recognitions. If your application
requires extra Dialect resolution capabilities, it would simply register a custom implementation requires extra Dialect resolution capabilities, it would simply register a custom implementation
of <interfacename>org.hibernate.dialect.resolver.DialectResolver</interfacename> as follows: of <interfacename>org.hibernate.service.jdbc.dialect.spi.DialectResolver</interfacename> as follows:
</para> </para>
<!-- document an example using the service registry --> <!-- document an example using the service registry -->
<para> <para>
Registered <interfacename>org.hibernate.dialect.resolver.DialectResolver</interfacename> are Registered <interfacename>org.hibernate.service.jdbc.dialect.spi.DialectResolver</interfacename> are
<emphasis>prepended</emphasis> to an internal list of resolvers, so they take precedence <emphasis>prepended</emphasis> to an internal list of resolvers, so they take precedence
before any already registered resolvers including the standard one. before any already registered resolvers including the standard one.
</para> </para>

View File

@ -1,10 +1,13 @@
<?xml version='1.0' encoding='utf-8' ?> <?xml version='1.0' encoding='utf-8' ?>
<!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_Development_Guide.ent"> <!ENTITY % BOOK_ENTITIES SYSTEM "Hibernate_Development_Guide.ent">
%BOOK_ENTITIES; %BOOK_ENTITIES;
]> ]>
<chapter> <chapter id="devguide-mappingEntities">
<title>Mapping entities</title> <title>Mapping entities</title>
<section> <section>
<title>Hierarchies</title> <para> </para> </section> </chapter> <title>Hierarchies</title>
<para></para>
</section>
</chapter>

View File

@ -1,7 +1,9 @@
<?xml version='1.0' encoding='utf-8' ?> <?xml version='1.0' encoding='utf-8' ?>
<!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_Development_Guide.ent"> <!ENTITY % BOOK_ENTITIES SYSTEM "Hibernate_Development_Guide.ent">
%BOOK_ENTITIES; %BOOK_ENTITIES;
]> ]>
<chapter> <chapter>
<title>Native-SQL</title> <para> </para> </chapter> <title>Native-SQL</title>
<para></para>
</chapter>

View File

@ -82,14 +82,12 @@ entityManager.persist(fritz);]]>
</programlisting> </programlisting>
</example> </example>
<sidebar> <para>
<para> <interfacename>org.hibernate.Session</interfacename> also has a method named <methodname>persist</methodname>
<interfacename>org.hibernate.Session</interfacename> also has a method named <methodname>persist</methodname> which follows the exact semantic defined in the JPA specification for the <methodname>persist</methodname>
which follows the exact semantic defined in the JPA specification for the <methodname>persist</methodname> method. It is this method on <interfacename>org.hibernate.Session</interfacename> to which the
method. It is this method on <interfacename>org.hibernate.Session</interfacename> to which the Hibernate <interfacename>javax.persistence.EntityManager</interfacename> implementation delegates.
Hibernate <interfacename>javax.persistence.EntityManager</interfacename> implementation delegates. </para>
</para>
</sidebar>
<para> <para>
If the <classname>DomesticCat</classname> entity type has a generated identifier, the value is associated If the <classname>DomesticCat</classname> entity type has a generated identifier, the value is associated

View File

@ -227,7 +227,7 @@
Contract for Hibernate to obtain <classname>org.hibernate.dialect.Dialect</classname> Contract for Hibernate to obtain <classname>org.hibernate.dialect.Dialect</classname>
instance to use. This is either explicitly defined by the instance to use. This is either explicitly defined by the
<property>hibernate.dialect</property> property or determined by the <property>hibernate.dialect</property> property or determined by the
<xref id="service-DialectResolver"/> service which is a delegate to this service. <xref linkend="services-DialectResolver"/> service which is a delegate to this service.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>

View File

@ -390,7 +390,7 @@
<para> <para>
For objects attached to a particular Session, the two notions are equivalent, and JVM identity for database For objects attached to a particular Session, the two notions are equivalent, and JVM identity for database
identity is guaranteed by Hibernate. The application might concurrently access a business object with the same identity is guaranteed by Hibernate. The application might concurrently access a business object with the same
identity in two different sessions, the two instances are actually actually different, in terms of JVM identity in two different sessions, the two instances are actually different, in terms of JVM
identity. Conflicts are resolved using an optimistic approach and automatic versioning at flush/commit time. identity. Conflicts are resolved using an optimistic approach and automatic versioning at flush/commit time.
</para> </para>
<para> <para>