resin3.0のmysqlに接続するようにhibernate2.1.2を設定します
レジン3.0でmysqlに接続するようにhibernate2.1.2を設定します
作者: ハマル
同意:
樹脂3は、樹脂3.0のインストールルートディレクトリを表します
hibernate2 は、hibernate2.1.2 のインストール ルート ディレクトリを表します
1. ウェブアプリケーションのルートを、resin3mydomain ディレクトリなどの、resin3 の下に確立します (mydomain のディレクトリ名は任意に選択でき、後で設定ファイルで設定できます)
2. 樹脂 3mydomain ディレクトリ内に、resin3mydomainWEB-INFclasses ディレクトリと樹脂 3mydomainWEB-INFlib ディレクトリを作成します。
これら 2 つのディレクトリは、この Web アプリケーション コンテキストのクラス ローダー検索パスに対応します (jar の場合はresin3mydomainWEB-INFlib、クラス ファイルの場合はresin3mydomainWEB-INFclasses)。これら 2 つのパスを、アプリケーション ライブラリ クラス パス (このアプリケーションに関連する jar クラス ライブラリの保存に使用) とコンテキスト クラス パス (このアプリケーションのクラス ファイルおよび XML 構成ファイルの保存に使用) と呼びます。
また、resin3lib ディレクトリと呼ばれるパスもあります。これをグローバル ライブラリ クラス パス (resin3 サーバーに保存され、サーバー上のすべての Web アプリケーションによって共有される関連する jar クラス ライブラリ) と呼びます。
3. この例では mysql データベースを使用するため、mysql jdbc ドライバーの jar パッケージ (mm.mysql-2.0.4-bin.jar) をresin3lib ディレクトリに配置します。その後、ドライバーはすべての Web アプリケーションで使用されます。
4. hibernate2 hibernate2.jar ファイルをresin3mydomainWEB-INFlibディレクトリにコピーし、次にhibernate2libディレクトリ内の必要なjarファイルをresin3mydomainWEB-INFlibディレクトリにコピーします。どのパッケージが必要かわからない場合は、hibernate2libREADME.txt ファイルを参照するか、より簡単に、hibernate2lib ディレクトリー内のすべての jar ファイルをresin3mydomainWEB-INFlib ディレクトリーにコピーします。
5. 次に、Resin の JDBC データベース接続プールの構成を開始します。樹脂3confresin.confファイルを変更します
a) Web アプリを検索し、Web アプリをカスタム アプリケーション ディレクトリ mydomain に置き換えます。
b)
要素を見つけて、このファイルのコメントは HTML スタイルのコメント メソッド を使用します。
c) 要素を次の形式に変更します
<データベース>
jdbc/mysql
<ドライバータイプ="org.gjt.mm.mysql.Driver">
ドライバー>
<準備されたステートメントのキャッシュ サイズ>8準備されたステートメントのキャッシュ サイズ>
20最大接続数>
30 秒最大アイドル時間>
データベース>
以上で、Resin の jdbc コネクションプールの設定が完了しました。
6. hibernate2src ディレクトリー内の hibernate.properties、log4j.properties、および oscache.properties ファイルを、resin3 mydomainWEB-INFclasses ディレクトリーにコピーします。
7. mysql データベースを使用しているため、hibernate.properties ファイル内の mysql 部分の構成を変更し、元のデフォルトの HypersonicSQL 構成をコメントアウトします。コメントの設定は、文の前に # 記号を追加することです。例:
#hibernate.dialect net.sf.hibernate.dialect.HSQLDialect
以下は典型的な mysql 構成です:
hibernate.dialect net.sf.hibernate.dialect.MySQLDialect
hibernate.connection.driver_class org.gjt.mm.mysql.Driver
hibernate.connection.driver_class com.mysql.jdbc.Driver
hibernate.connection.url jdbc:mysql://192.162.125.3:3306/mydb
hibernate.connection.username root
hibernate.connection.password 12345678
変更する必要があるのは次の 3 行です:
URL は JDBC 接続記述子を指し、形式は jdbc:mysql://データベース IP:ポート番号/データベース名です
ユーザー名はデータベースへのログインに使用されるユーザー名を指します
パスワードこのユーザーのパスワード
8. Hibernate と樹脂のデータベース接続プールをバインドします。ディレクトリ内に hibernate.cfg.xml ファイルを作成します。 ファイルの内容は次のとおりです
PUBLIC "-//Hibernate/Hibernate 構成 DTD//EN"
「http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd」>
<休止状態構成>
,,,,,,,,、
&lt;プロパティ名= "show_sql"&gt; true&lt;/property&gt;
,,、、
セッションファクトリー>
要素は、データベースに接続するために樹脂で定義された jndi を使用するように Hibernate に指示します。
これは、User.hbm.xml が永続クラス User に対応する Hibernate XML マッピング ファイルであることを宣言します。このファイルには、POJO クラスをデータベース テーブル (または複数のデータベース テーブル) にマップするメタデータが含まれています。このドキュメントについては後ほど説明します。まずこの POJO クラスを作成してから、それを宣言するマッピング メタデータを見てみましょう。
9. mysql でユーザー テーブルを作成します。テーブルの形式は次のとおりです。
User_id パスワード ニックネーム E_mail
1 6666 ハマル hamal@sohu.com
2 6666 吸血鬼吸血鬼@sina.com
3 6666 アンデ ande@yahoo.com
resin3 mydomainWEB-INFclasses ディレクトリに 3 つの新しい Java ファイル、Test.java、HibernateUtil.java、および User.java を作成します。
HibernateUtil.java のソース コードは次のとおりです。 このクラスは、静的な SessionFactory を取得するために使用される補助クラスであり、データベースを担当し、1 つの XML 設定ファイル (hibernate.cfg.xml) にのみ対応します。
net.sf.hibernate.*;
をインポートします
インポート net.sf.hibernate.cfg.*;
パブリック クラス HibernateUtil {
プライベート静的最終セッションファクトリー sessionFactory;
静的{
試してみてください{
sessionFactory = new Configuration().configure().buildSessionFactory();
} catch (HibernateException ex) {
throw new RuntimeException("SessionFactory 構築時の例外: " + ex.getMessage(), ex);
}
}
パブリック静的最終 ThreadLocal セッション = new ThreadLocal();
パブリック静的セッション currentSession() が HibernateException をスローする {
セッション s = (セッション) session.get();
// このスレッドにまだセッションがない場合は、新しいセッションを開きます
if (s == null) {
s = sessionFactory.openSession();
セッション.セット;
}
戻り値;
}
public static void closeSession() throws HibernateException {
セッション s = (セッション) session.get();
Session.set(null);
if (s != null)
s.close();
}
}
User.java のソース コードは次のとおりです。 Hibernate は、通常の Java オブジェクト (Plain Old Java Object、POJO、Plain Ordinary Java Object とも呼ばれる) を永続クラスに変換します。 POJO は JavaBean によく似ており、プロパティには getter メソッドと setter メソッドを通じてアクセスし、内部実装の詳細を外部から隠します。
パブリック クラス ユーザー {
プライベート整数 ID;
プライベート文字列ニックネーム;
プライベート文字列パスワード ;
プライベート文字列メール;
public User() {
}
public Integer getId() {
ID を返します;
}
public void setId(整数 ID) {
this.id = id;
}
public String getNick() {
ニックを返してください;
}
public void setNick(String ニック) {
this.nick = ニック;
}
public String getPassword() {
パスワードを返します;
}
public void setPassword(String パスワード) {
this.password = パスワード;
}
public String getEmail() {
メールを返信してください;
}
public void setEmail(String email) {
this.email = メール;
}
}
Test.java ソース代码如下:
import javax.naming.*;
net.sf.hibernate.*;
をインポートします
import java.util.*;
パブリッククラステスト{
void テスト(){
}
public static void insert(){
試してください{
セッション hSession = HibernateUtil.currentSession();
トランザクション tx= hSession.beginTransaction();
ユーザー newp = new User();
整数 ID = new Integer("4");
newp.setId(id);
newp.setNick("愛");
newp.setPassword("123");
newp.setEmail("test@sohu.com");
hSession.save(newp);
tx.commit();
HibernateUtil.closeSession();
}catch(例外 e){
e.printStackTrace();
}
}
}
10. 编写Hibernate XML映射ファイル
在resin3 mydomainWEB-INFclasses目录下新建User.hbm.xml文件,文件内容如下:
PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"
「http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd」>
<休止状態マッピング>
<クラス名="ユーザー" テーブル="ユーザー">
<列名="user_id" sql-type="Integer" not-null="true"/>
<ジェネレータークラス="割り当て済み"/>
<プロパティ名="パスワード" タイプ="java.lang.String">
<列名="パスワード" sql-type="varchar(20)"/>
<プロパティ名="nick" type="java.lang.String">
<列名="ニックネーム" sql-type="varchar(50)"/>
<プロパティ名="email" type="java.lang.String">
<列名="e_mail" sql-type="varchar(30)"/>
クラス>
簡単な説明:
要素の name 属性は User クラスのフルパス名 (つまり、パッケージ名 + クラス名の形式) を表し、table 属性はユーザー クラスのデータベース テーブル名のマッピング。
要素はテーブルの主キーを表し、name 属性は User クラスの対応するクラス属性名を表します。
要素は、id 属性に対応するデータベース ユーザー テーブルの user_id フィールドを表します。
11. インターフェーステスト:
次のように、resin3mydomain ディレクトリに新しい test.jsp ファイルを作成します。
<%@ page contentType="text/html; charset=gb2312" %>
<頭>
これはテストです!
これはテストです!
<%Test.insert();%>