ホームページ  >  記事  >  バックエンド開発  >  resin3.0 での hibernate2.1.2 接続の構成 mysql_PHP チュートリアル

resin3.0 での hibernate2.1.2 接続の構成 mysql_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 17:03:44904ブラウズ

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" %>



<頭>

これはテストです! <br> </head><br> <br> <br> <br> これはテストです!<br> <br> <%Test.insert();%><br> <br> </body><br> <br> </html><br> <br> <br> <br> <br> <br> 12. テスト<br> <br> さて、準備がすべて完了したので、テストを開始しましょう。 <br> <br> Rensinサーバーを起動します。起動ファイルはresin3binhttpd.exeで、ファイルをダブルクリックします。 <br> <br> テスト前に確認したmysqlのuserテーブルの内容は以下の通りです。 <br> <br> User_id パスワード ニックネーム E_mail<br> 1 6666 ハマル hamal@sohu.com<br> 2 6666 吸血鬼吸血鬼@sina.com<br> 3 6666 アンデ ande@yahoo.com<br> <br> 次に、IE を開き、アドレス バーに http://localhost:8080/test.jsp<br> と入力します。 <br> This is a test! がインターフェースに正常に表示されたら、次のようにデータベースの内容を確認します。 <br> User_id パスワード ニックネーム E_mail<br> 1 6666 ハマル hamal@sohu.com<br> 2 6666 吸血鬼吸血鬼@sina.com<br> 3 6666 アンデ ande@yahoo.com<br> 4 123 愛 test@sohu.com<br> <br> <br> おめでとうございます。この例は完了しました。 <br> <br><br>http://www.bkjia.com/PHPjc/630945.html<p align="left"></p> <div style="display:none;">www.bkjia.com<span id="url" itemprop="url"></span>本当<span id="indexUrl" itemprop="indexUrl"></span>http://www.bkjia.com/PHPjc/630945.html<span id="isOriginal" itemprop="isOriginal"></span>技術記事<span id="isBasedOnUrl" itemprop="isBasedOnUrl"></span>樹脂 3.0 の mysql に接続するように hibernate2.1.2 を設定します。 樹脂 3.0 の mysql に接続するように hibernate2.1.2 を設定します。 作成者: hamal 規則: 樹脂 3 は、樹脂 3.0 のインストール ルート ディレクトリを表します。 <span id="genre" itemprop="genre"></span> </div></database></div><div class="nphpQianMsg"><div class="clear"></div></div><div class="nphpQianSheng"><span>声明:</span><div>この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。</div></div></div><div class="nphpSytBox"><span>前の記事:<a class="dBlack" title="PHP_PHP チュートリアルを使用して画像をデータベースにアップロードする" href="http://m.php.cn/ja/faq/299311.html">PHP_PHP チュートリアルを使用して画像をデータベースにアップロードする</a></span><span>次の記事:<a class="dBlack" title="PHP_PHP チュートリアルを使用して画像をデータベースにアップロードする" href="http://m.php.cn/ja/faq/299313.html">PHP_PHP チュートリアルを使用して画像をデータベースにアップロードする</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>関連記事</h2><em><a href="http://m.php.cn/ja/article.html" class="bBlack"><i>続きを見る</i><b></b></a></em><div class="clear"></div></div><ul class="nphpXgwzList"><li><b></b><a href="http://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="http://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="http://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="http://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="http://m.php.cn/ja/faq/2.html" title="正規表現内のすべての式記号 (概要)" class="aBlack">正規表現内のすべての式記号 (概要)</a><div class="clear"></div></li></ul></div></div><footer><div class="footer"><div class="footertop"><img src="/static/imghwm/logo.png" alt=""><p>福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!</p></div><div class="footermid"><a href="http://m.php.cn/ja/about/us.html">私たちについて</a><a href="http://m.php.cn/ja/about/disclaimer.html">免責事項</a><a href="http://m.php.cn/ja/update/article_0_1.html">Sitemap</a></div><div class="footerbottom"><p> © php.cn All rights reserved </p></div></div></footer><script>isLogin = 0;</script><script type="text/javascript" src="/static/layui/layui.js"></script><script type="text/javascript" src="/static/js/global.js?4.9.47"></script></div><script src="https://vdse.bdstatic.com//search-video.v1.min.js"></script><link rel='stylesheet' id='_main-css' href='/static/css/viewer.min.css' type='text/css' media='all'/><script type='text/javascript' src='/static/js/viewer.min.js?1'></script><script type='text/javascript' src='/static/js/jquery-viewer.min.js'></script><script>jQuery.fn.wait = function (func, times, interval) { var _times = times || -1, //100次 _interval = interval || 20, //20毫秒每次 _self = this, _selector = this.selector, //选择器 _iIntervalID; //定时器id if( this.length ){ //如果已经获取到了,就直接执行函数 func && func.call(this); } else { _iIntervalID = setInterval(function() { if(!_times) { //是0就退出 clearInterval(_iIntervalID); } _times <= 0 || _times--; //如果是正数就 -- _self = $(_selector); //再次选择 if( _self.length ) { //判断是否取到 func && func.call(_self); clearInterval(_iIntervalID); } }, _interval); } return this; } $("table.syntaxhighlighter").wait(function() { $('table.syntaxhighlighter').append("<p class='cnblogs_code_footer'><span class='cnblogs_code_footer_icon'></span></p>"); }); $(document).on("click", ".cnblogs_code_footer",function(){ $(this).parents('table.syntaxhighlighter').css('display','inline-table');$(this).hide(); }); $('.nphpQianCont').viewer({navbar:true,title:false,toolbar:false,movable:false,viewed:function(){$('img').click(function(){$('.viewer-close').trigger('click');});}}); </script></body></html>