* JPA(Hibernate)サンプルコード [#acf5c0ff]

** 環境 [#b1eb50f5]
- Eclipse
- Maven
- PostgreSQL
- JPA(Hibernate)

** プロジェクト作成 [#v4a8e73e]
- Eclipseを起動する。
- [File] -> [New] -> [Other] を開く。
- Maven Projectを選び、[Next]を押下
- そのままで[Next]を押下。
- Archetypeはmaven-archetype-quickstartである事を確認して[Next]を押下。
- 以下の様に入力する。
-- GroupId jpa-sample
-- ArticatId app01
- [Finish]を押下する。

** 依存ライブラリの追加 [#x84733cd]
- ProjectExplorerでpom.xmlを右クリックし、[Maven] -> [Add Dependency]を開く。
- [Enter groupId, artifactId or ... patter (*)]にライブラリ名を入力し、検索結果が表示される[Serach Result]から目的のライブラリを選び、[OK]を押下する。
- 追加するライブラリは以下。log4jはバージョン1.2.14以下を選ぶ。
-- commons-logging
-- log4j
-- commons-lang
-- hibernate-entitymanager
-- postgresql

** リソースフォルダの作成 [#yb2ad963]
- Project Explorerでapp01を右クリックして[New] -> [Source Folder]を開く。
- Folder nameをsrc/main/resourcesと入力して[Finish]を押下する。

** JPAの設定 [#bf72290c]
- src/main/resources/META-INFフォルダを作成する。
- 上記フォルダ内にpersitentence.xmlを作成する。内容は以下の通り。

 <?xml version="1.0" encoding="UTF-8" ?>
 <persistence xmlns="http://java.sun.com/xml/ns/persistence"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
	version="1.0">
 
	<persistence-unit name="myPersistenceUnit" transaction-type="RESOURCE_LOCAL">
		<provider>org.hibernate.ejb.HibernatePersistence</provider>
		<properties>
			<property name="hibernate.connection.driver_class" value="org.postgresql.Driver" />
			<property name="hibernate.connection.url" value="jdbc:postgresql://my-db-server/mydb01" />
			<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect" />
			<property name="hibernate.connection.username" value="db_user" />
			<property name="hibernate.connection.password" value="db_passwd" />
			<property name="hibernate.show_sql" value="true" />
		</properties>
	</persistence-unit>
 </persistence>

** サンプルコード [#n10e780c]

*** エンティティクラス [#xebe777c]
src/main/java/jpa_sample/app01/entity/T1.java

 package jpa_sample.app01.entity;
 
 import javax.persistence.Column;
 import javax.persistence.Entity;
 import javax.persistence.GeneratedValue;
 import javax.persistence.GenerationType;
 import javax.persistence.Id;
 import javax.persistence.Table;
 
 @Entity
 @Table(name = "T1")
 public class T1 {
 
 	@Id
 	@GeneratedValue(strategy = GenerationType.IDENTITY)
 	private Long id;
 	
 	@Column(nullable = false, length = 255, unique = false)
 	private String name;
 
 	public T1() {
 	}
 
 	public Long getId() {
 		return id;
 	}
 
 	public void setId(Long id) {
 		this.id = id;
 	}
 
 	public String getName() {
 		return name;
 	}
 
 	public void setName(String name) {
 		this.name = name;
 	}
 
 }

*** 利用クラス [#yf61e68e]
src/test/java/jpa_sample/app01/Main.java

 package jpa_sample.app01;
 
 import javax.persistence.EntityManager;
 import javax.persistence.EntityManagerFactory;
 import javax.persistence.Persistence;
 
 import jpa_sample.app01.entity.T1;
 
 public class Main {
 
     public static void main(String[] args) {
         EntityManagerFactory emf = Persistence
                 .createEntityManagerFactory("my-persistence-unit");
         EntityManager em = emf.createEntityManager();
         String sql = "from T1 where name = ?";
         T1 t1 = (T1) em.createQuery(sql).setParameter(1, "taro")
                 .getSingleResult();
         System.out.println("### RESULT: " + t1);
     }
 
 }

** 参考 [#qc1c50af]
http://trasis.jp/blog/lab/2008/09/hibernate-jpa%E7%92%B0%E5%A2%83%E6%A7%8B%E7%AF%89.html


トップ   編集 差分 バックアップ 添付 複製 名前変更 リロード   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS