Hibernate 의 입문 편 을 되돌아보다

19744 단어 프레임hibernate
hibenate 를 배 운 지 오래 되 었 지만 회사 의 프로젝트 는 my batis 를 프로젝트 의 지속 적 인 프레임 워 크 로 사용 하기 때문에 실제 업무 에서 hibenate 는 쓸모 가 없다.시간 이 흐 르 면서 최초의 히 베 네 이 트 를 잊 지 않 기 위해 기념 으로 글 을 쓴다.
기본 개념
1. 기본 역할: hibenate 프레임 워 크 는 주로 데이터 베 이 스 를 조작 하 는 데 사용 되 며 JDBC 에 대한 패키지 입 니 다.응용 에서 데이터 액세스 층 을 실현 합 니 다.
2. 장점:
  • 복잡 한 SQL 을 많이 만 드 는 것 을 피한다
  • hibernate 는 자동 으로 SQL 을 생 성하 여 서로 다른 데이터베이스 의 이식 성 을 강화한다.
  • 데이터 기록 과 자바 대상 간 의 맵 을 자동 으로 완성 합 니 다.

  • 3. 기본 원리: ORM, Object 관계 Mapping, 대상 관계 맵.자바 대상 과 데이터 시트 기록 간 의 매 핑 을 완성 할 수 있 으 며, 업무 층 에서 대상 을 조작 하면 데이터 베 이 스 를 조작 할 수 있 습 니 다.
    기본 사용
    1. 주요 절차
  • 프로젝트 를 만 들 고 해당 하 는 jar
  • 를 도입 합 니 다.
  • src 에 hibenate. cfg. xml 메 인 프로필 을 추가 하여 데이터베이스 연결 매개 변수
    
    
    
    <hibernate-configuration>
        <session-factory>
    
            
            <property name="show_sql">trueproperty>
            <property name="format_sql">trueproperty>
            
            <property name="current_session_context_class">threadproperty>
    
            
            <property name="dialect">org.hibernate.dialect.MySQLDialectproperty>
    
            
            <property name="connection.driver_class">com.mysql.jdbc.Driverproperty>
            
            <property name="connection.url">jdbc:mysql://localhost:3306/earl_testproperty>
            
            <property name="connection.username">rootproperty>
            
            <property name="connection.password">property>
    
            
            <mapping resource="config/mapping/Pet.hbm.xml"/>
        session-factory>
    hibernate-configuration>
  • 를 정의 합 니 다.
  • 실체 류 Pet 를 정의 합 니 다. 다음 과 같 습 니 다.
    import java.sql.Date;
    
    public class Pet {
    
        private int id;
        private String name;
        private String owner;
        private String species;
        private int sex;
        private Date birth;
        private Date death;
        private boolean is_dead;
    
    
        //TODO      getter setter,  toString  
        ......
    }
  • 맵 설명 파일 을 정의 합 니 다. 예 를 들 어 Pet. hbm. xml
    
    
    
    <hibernate-mapping>
        <class name="com.earl.entity.Pet" table="pet" >
            <id name="id" column="id" type="integer">
                <generator class="identity">generator>
            id>
            <property name="name" column="name" type="string"/>
            <property name="owner" column="owner" type="string"/>
            <property name="species" column="species" type="string"/>
            <property name="sex" column="sex" type="int"/>
            <property name="birth" column="birth" type="date"/>
            <property name="death" column="death" type="date"/>
            
            <property name="is_dead" column="is_dead" type="yes_no"/>
        class>
    hibernate-mapping>
  • hibenate API 를 이용 하여 첨삭 검사 작업 완료

  • 2. 기본 동작 은 데이터베이스 에 대한 CURD 동작 입 니 다.먼저 테스트 표를 만 듭 니 다. 이 표 도 제 가 연습 할 때 다른 곳 에서 찾 아 온 것 입 니 다. 다음은 표 문구 와 데 이 터 를 만 드 는 것 입 니 다.
    CREATE TABLE IF NOT EXISTS `pet` (
      `id` int(10) NOT NULL AUTO_INCREMENT,
      `name` varchar(20) DEFAULT NULL,
      `owner` varchar(20) DEFAULT NULL,
      `species` varchar(20) DEFAULT NULL,
      `sex` int(11) DEFAULT NULL,
      `birth` date DEFAULT NULL,
      `death` date DEFAULT NULL,
      `is_dead` char(50) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;
    
    
    INSERT INTO `pet` (`id`, `name`, `owner`, `species`, `sex`, `birth`, `death`, `is_dead`) VALUES
        (1, 'nokia', 'Harold', 'cat', 1, '1993-02-04', NULL, 'N'),
        (2, 'Claws', 'Gwen', 'cat', 0, '1994-03-17', NULL, 'n'),
        (3, 'Buffy', 'Harold', 'dog', 1, '1989-05-13', NULL, 'n'),
        (4, 'Fang', 'Benny', 'dog', 1, '1990-08-27', NULL, 'n'),
        (5, 'Bowser', 'Diane', 'dog', 0, '1979-08-31', '1995-07-29', 'y'),
        (6, 'Chirpy', 'Gwen', 'bird', 1, '1998-09-11', NULL, 'n'),
        (7, 'Whistler', 'Gwen', 'bird', 1, '1997-12-09', NULL, 'n'),
        (8, 'Slim', 'Benny', 'snake', 0, '1996-04-29', NULL, 'n'),
        (9, 'Tom', 'Jerry', 'cat', 1, '2016-01-11', NULL, 'N');

    잔말 말고 구체 적 인 사용 을 살 펴 보 자.
  • 추가
  • @Test
    public void testInsert(){
    
        java.util.Date birthDate=new java.util.Date();
    
        //    ,     
        Pet pet=new Pet();
        pet.setName("Tom");
        pet.setOwner("Jerry");
        pet.setSpecies("cat");
        pet.setSex(1);
        pet.setBirth(new Date(birthDate.getTime()));
        pet.setIs_dead(true);
    
        //  configuration  session  ,    session    
        Configuration configuration=new Configuration();
        configuration.configure();
        SessionFactory factory=configuration.buildSessionFactory();
        Session session=factory.openSession();
        //        ,    ,  ,    ,         
        Transaction transaction=session.beginTransaction();
        //  hibernate API    
        session.save(pet);
        transaction.commit();
        session.close();
    }
  • 삭제
  • @Test
    public void testDelete(){
    
        Pet pet=new Pet();
        pet.setId(11);
    
        //  SessionUtil  Session           
        Session session=SessionUtil.getSession();
        Transaction transaction=session.beginTransaction();
        session.delete(pet);
        transaction.commit();
        SessionUtil.closeSession(session);
    }
  • 수정
  • @Test
    public void testUpdate(){
    
        Session session=SessionUtil.getSession();
        Transaction transaction=session.beginTransaction();
    
        //      ,                  ,         
        //load         ,            
        Pet pet=session.load(Pet.class, 9);
        pet.setSpecies("cat");
        pet.setName("Tom");
        pet.setOwner("Jerry");
    
        session.update(pet);
        transaction.commit();
        SessionUtil.closeSession(session);
    
    }
  • 조회 방법 은 여러 가지 가 있 는데 여기 서 먼저 HQL 문 구 를 사용 하여 조회 하 는 것 을 초보 적 으로 소개 한다.HQL 이 뭐 예요?Hibernate Query Language, hibernate 쿼 리 언어.한눈 에 형제 가 있다 고 생각 하지 않 아 요?맞 아, 바로 SQL 이 야.이것 은 SQL 문장 과 겉모습 이 비슷 할 뿐만 아니 라 사용 에 있어 서도 공 통 된 부분 이 많다.다음 두 문장 을 보십시오. HQL: select from Pet SQL: select * from pet 그들의 문법 은 대체적으로 같 습 니 다. 다른 것 은 HQL 이 대상 Pet, SQL 이 대상 인 데이터 테이블 pet 입 니 다.다음 사례 에 대해 서 는 여기 서 간단히 말씀 드 리 고 HQL 에 대해 더 자세히 소개 하 겠 습 니 다.
  • @Test
    public void testFindAll(){
        Session session=SessionUtil.getSession();
        String hql="from Pet";
        Query query=session.createQuery(hql);
        //         ,           pet  
        List pets=query.list();
        for(Pet pet:pets){
            System.out.println(pet);
        }
        SessionUtil.closeSession(session);
    }

    3. 총화
    이상 은 hibenate 에 대한 기본 적 인 사용 이 었 습 니 다.그 다음 에 hibenate 의 주요 프로필 인 hibenate. cfg. xml, 대상 맵 파일 hbm. xml, 그리고 HQL 에 대해 더 자세 한 설명 을 할 것 입 니 다.OK,bye,See you later!

    좋은 웹페이지 즐겨찾기