>  기사  >  Java  >  주석을 사용한 ORM 매핑 소개

주석을 사용한 ORM 매핑 소개

零下一度
零下一度원래의
2017-07-23 14:18:111982검색

지난 2년 동안 상대적으로 안정적인 일부 엔터티 클래스의 ORM 매핑에 주석을 사용하는 프로젝트가 늘어나 프로그래밍이 더욱 간결하고 단순해졌습니다. 실제로 ORM 매핑에 주석을 사용하는 것과 매핑에 xml을 사용하는 것 사이의 작업 프로세스에는 큰 변화가 없습니다. 주요 단계는 패키지 가져오기, 주석이 달린 엔터티 클래스 작성, 핵심 구성 파일 작성, 테스트 클래스 작성입니다.

프로젝트 코드가 GitHub에 업로드되었습니다. 프로젝트 이름: HibernateUseAnnotation

전체 프로젝트 구조는 다음과 같습니다.

1. 가이드 패키지

  작성자가 사용 중입니다.

2. 쓰기 엔터티 클래스

  매핑에 사용되는 주석은 기본적으로 javax.persistence.* 패키지에 정의되어 있습니다. 나는 일반적으로 다음 네 가지를 사용합니다.

@Entity 주석은 이 클래스를 엔터티로 표시합니다.
@Table 주석은 이 엔터티의 데이터가 유지될 테이블의 이름을 지정합니다. @Table 주석을 사용하지 않으면 최대 절전 모드는 기본적으로 클래스 이름을 테이블 이름으로 사용합니다.
@Id 주석은 이 엔터티의 식별자를 표시합니다.
@Column 주석은 이 속성 또는 필드의 열 세부정보를 지정합니다. @Column 주석을 지정하지 않으면 기본적으로 속성 이름이 열 이름으로 사용됩니다.
 1 package com.rocky.domain; 2  3 import javax.persistence.Entity; 4 import javax.persistence.Id; 5 import javax.persistence.Table; 6  7 @Entity 8 @Table(name = "tb_user") 9 public class User10 {11     @Id12     private Integer uId;13     private String uName;14     private Integer uAge;15     public User()16     {17         super();18     }19     @Override20     public String toString()21     {22         return "User [uId=" + uId + ", uName=" + uName + ", uAge=" + uAge + "]";23     }24     public Integer getuId()25     {26         return uId;27     }28     public void setuId(Integer uId)29     {30         this.uId = uId;31     }32     public String getuName()33     {34         return uName;35     }36     public void setuName(String uName)37     {38         this.uName = uName;39     }40     public Integer getuAge()41     {42         return uAge;43     }44     public void setuAge(Integer uAge)45     {46         this.uAge = uAge;47     }48 }

3. 핵심 구성 파일 작성

Annotation을 사용한 구성 파일은 기본적으로 xml로 매핑된 구성 파일과 동일하지만, 외부 매핑을 도입할 때 사용하는 속성은 리소스 속성이 아닌 클래스입니다. .

 1 <?xml version=&#39;1.0&#39; encoding=&#39;UTF-8&#39;?> 2 <!DOCTYPE hibernate-configuration PUBLIC 3           "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 4           "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 5  6 <hibernate-configuration> 7     <session-factory> 8  9         <!--指定数据库的参数  -->10         <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>11         <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>12         <property name="hibernate.connection.url">jdbc:mysql://192.168.100.100:3306/test</property>13         <property name="hibernate.connection.username">root</property>14         <property name="hibernate.connection.password">1</property>15         16         <!--指定hibernate是否显式SQL语句及其格式化  -->17         <property name="hibernate.show_sql">true</property>18         <property name="hibernate.format_sql">true</property>19         20         <!--指定表的生成方式-即是否由hibernate自动创建表,其取值为:create-drop、21          create、validate、update-->22         <property name="hibernate.hbm2ddl.auto">update</property>23         24         <!--引入 ORM配置文件 -->25         <mapping class="com.rocky.domain.User"/>26     </session-factory>27 28 </hibernate-configuration>

4. 테스트 수업 작성하기

 1 package com.rocky.testdriver; 2  3 import org.hibernate.Session; 4 import org.hibernate.SessionFactory; 5 import org.hibernate.Transaction; 6 import org.hibernate.cfg.Configuration; 7  8 import com.rocky.domain.User; 9 10 public class TestDriver11 {12 13     public static void main(String[] args)14     {15         // 加载配置文件16         Configuration cfg = new Configuration();17         cfg.configure();18         // 创建会话工厂19         SessionFactory factory = cfg.buildSessionFactory();20         // 获取非线程绑定会话21         Session session = factory.openSession();22         // 开启事务23         Transaction tx = session.beginTransaction();24         // 创建User对象25         User user = new User();26         user.setuId(1);27         user.setuName("rocky");28         user.setuAge(28);29 30         // 将数据插入数据库31         session.save(user);32 33         // 提交事务34         tx.commit();35         // 关闭会话36         session.close();37     }38 39 }

위 내용은 주석을 사용한 ORM 매핑 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.