JPA(Hibernate)サンプルコード

環境

  • Eclipse
  • Maven
  • PostgreSQL
  • JPA(Hibernate)

プロジェクト作成

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

依存ライブラリの追加

  • 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

リソースフォルダの作成

  • Project Explorerでapp01を右クリックして[New] -> [Source Folder]を開く。
  • Folder nameをsrc/main/resourcesと入力して[Finish]を押下する。

JPAの設定

  • 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>

サンプルコード

エンティティクラス

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;
 	}
 
 }

利用クラス

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);
     }
 
 }

参考

http://trasis.jp/blog/lab/2008/09/hibernate-jpa%E7%92%B0%E5%A2%83%E6%A7%8B%E7%AF%89.html


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

Last-modified: 2012-09-26 (水) 18:15:39