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