Spring Data Jpa示例(IntelliJ maven項目)

1. 在IntelliJ中新建maven項目html

給出一個建好的示例,(本示例中省略了業務邏輯組件UserService)java

捕獲

2. 在pom.xml中配置依賴mysql

包括:
spring-context
spring-orm
spring-data-jpa
hibernate-core
hibernate-entitymanager
mysql-connector-java
commons-dbcp
junit
spring-test

代碼以下:spring

<dependencies>
    <!-- Spring & Spring Data JPA -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>4.2.3.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-orm</artifactId>
        <version>4.2.3.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-jpa</artifactId>
        <version>1.9.1.RELEASE</version>
    </dependency>

    <!-- Hibernate -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <version>4.3.11.Final</version>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>4.3.11.Final</version>
    </dependency>

    <!-- MySQL -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.37</version>
    </dependency>
    <dependency>
        <groupId>commons-dbcp</groupId>
        <artifactId>commons-dbcp</artifactId>
        <version>1.4</version>
    </dependency>

    <!-- Junit -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>4.2.3.RELEASE</version>
    </dependency>
</dependencies>

3. resources右鍵new一個Xml Configuration File--Spring Config配置文件:spring-config.xml(或者applicationContext.xml)sql

    配置dataSource、entityManagerFactory、transactionManager等。apache

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:jpa="http://www.springframework.org/schema/data/jpa"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">

    <jpa:repositories base-package="com.xin"/>

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/javaee"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>

    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="packagesToScan" value="com.xin"/>
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
                <property name="database" value="MYSQL"/>
                <property name="generateDdl" value="true"/>
                <property name="showSql" value="true"/>
                <property name="databasePlatform" value="org.hibernate.dialect.MySQL5InnoDBDialect"/>
            </bean>
        </property>
        <property name="jpaProperties">
            <value>
                hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
                hibernate.hbm2ddl.auto=update
                hibernate.show_sql=true    <!--此處的設置能夠覆蓋jpaVendorAdapter中的相關設置-->
                <!--hibernate.format_sql=true-->
            </value>
        </property>
    </bean>

    <!--配置針對JPA的局部事務管理器-->
    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory"/>
    </bean>
    <!--根據事務註解來生成事務代理-->
    <tx:annotation-driven transaction-manager="transactionManager"/>
</beans>

4. 新建User實體類,並進行Annotation註解app

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    private String firstname, lastname;
    private int age;
    private String address;
//省略構造方法和setter、getter方法
}

5. 新建DAO組件:UserRepository接口maven

讓此接口繼承Repository、CrudRepository、PagingAndSortingRepositories 或者 JpaRepository。JpaRepository接口有一實現類SimpleJpaRepository,上述接口聲明的方法均由該類實現。單元測試

public interface UserRepository extends JpaRepository<User, Long> {
    //能夠根據方法名進行衍生查詢,也能夠自定義查詢。
    @Query("select u from User u where u.lastname=?1")
    List<User> findByLastname(String lastname);
    
    Long countByLastname(String lastname);
}

6. 接下來即可使用junit單元測試類進行測試了測試

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:spring-config.xml")
public class UserRepositoryTest {
    @Autowired
    private UserRepository userRepository;

    @Test
    public void testFindByLastname() throws Exception {
        User user = new User("lunhui","wei",28, "nanle");
        userRepository.save(user);
    }
}
相關文章
相關標籤/搜索