使用Maven開發一個簡單的SpringData


1:創建Maven項目

2:添加依賴(修改pom.xml為以下代碼)

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.gx</groupId>
  <artifactId>SpringData</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>SpringData Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.0.1</version>
        <scope>provided</scope>
    </dependency>
    <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.38</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>4.3.5.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>4.3.5.RELEASE</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.springframework.data/spring-data-jpa -->
    <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-jpa</artifactId>
        <version>1.8.0.RELEASE</version>
    </dependency>
    <!-- hibernate-entity -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>4.3.6.Final</version>
    </dependency>
  </dependencies>
  <build>
    <finalName>SpringData</finalName>
  </build>
</project>

3:創建配置文件spring-data-beans.xml(名字隨便取)內容如下

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:jpa="http://www.springframework.org/schema/data/jpa"
       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-1.3.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd">

    <!-- 配置數據源 -->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="username" value="root" />
        <property name="password" value="root" />
        <property name="url" value="jdbc:mysql://localhost:3307/test" />
    </bean>
    
    <!-- 配置EntityManagerFactory -->
    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <!-- 設置jpa適配器 -->
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
        </property>
        <!-- 采用注解的方式,掃描包下面的java類 -->
        <property name="packagesToScan" value="com.gx"/>
        <!-- jpa的相關配置 -->
        <property name="jpaProperties">
            <props>
                <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
                <prop key="hibernate.show_sql">true</prop><!--執行的時候是否顯示SQL-->
                <prop key="hibernate.format_sql">true</prop><!--執行的時候SQL是否格式化-->
                <prop key="hibernate.hbm2ddl.auto">update</prop><!--如果沒有是否創建-->
            </props>
        </property>
    </bean>
    
    <!--配置事務管理器-->
    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory"/>
    </bean>

    <!--配置支持注解的事務-->
    <tx:annotation-driven transaction-manager="transactionManager"/>

    <!--配置spring data 需要掃描的包-->
    <jpa:repositories base-package="com.gx" entity-manager-factory-ref="entityManagerFactory"/>

    <!--在這個配置里面的內容spring都能夠自動找到,更方便-->
    <context:component-scan base-package="com.gx"/>

</beans>

4:創建測試類com.gx.SpringData測試配置文件spring-data-beans.xml里面配置的EntityManagerFactory是否成功

4.1:創建一個數據庫里面沒有的表的實體類(比如說User)內容如下

package com.gx.entity;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
/*
 * 這個Entity的注解會告訴配置文件這是一個實體類
 * 配置文件會根據EntityManagerFactory來判斷是否有這個表
 * 如果沒有回字段生成
 */
@Entity
public class User {
    /*最好使用封裝之后的類型
     * 因為在后面的類使用的時候需要用到泛型Repository<User, Integer>,這里的Integer就是主鍵Id
     */
    private Integer id;
    private String name;
    private Integer age;
    @GeneratedValue//這個注解是告訴配置文件這個id是自增的
    @Id//這個注解是告訴配置文件這是一個id
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    /*這個注解是設置表user里面的name字段的長度為20,默認不為空
     * 如果不設置的話默認是255
     */
    @Column(length=20,nullable=false)
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    @Override
    public String toString() {
        return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
    }
    
}

4.2:創建測試類com.gx.SpringData內容如下

package com.gx;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class SpringData {
    //獲取上下文
    private ApplicationContext ctx = null;
    @Before
    public void setup(){
        System.out.println("setup is working......");
        ctx = new ClassPathXmlApplicationContext("spring-data-beans.xml");
    }
    @After
    public void destory(){
        ctx = null;
        System.out.println("destory is working......");
    }
    @Test
    public void testEntityManagerFctory(){
        
    }
}

4.3:測試結果

5:在配置文件里面添加配置

    <!--配置事務管理器-->
    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory"/>
    </bean>

    <!--配置支持注解的事務-->
    <tx:annotation-driven transaction-manager="transactionManager"/>

    <!--配置spring data 需要掃描的包-->
    <jpa:repositories base-package="com.gx" entity-manager-factory-ref="entityManagerFactory"/>

    <!--在這個配置里面的內容spring都能夠自動找到,更方便-->
    <context:component-scan base-package="com.gx"/>

6:創建接口com.gx.repository.UserRepository

注意:

1:UserRepository里面的方法的名字是遵循一定的規則的,不能隨便亂取

2:Repository是springdata的核心接口,並且不提供任何方法

3:Repository<需要操作的實體類,實體類的id的類型> 是一個空接口(標記接口-->沒有包含方法聲明的接口)。因為UserRepository繼承了這個接口,所以會被spring管理

4:添加注解可以代替extends Repository<需要操作的實體類,實體類的id的類型> 

package com.gx.repository;

import org.springframework.data.repository.Repository;

import com.gx.entity.User;

public interface UserRepository extends Repository<User, Integer>{

    public User findByName(String name);
}

方法二:使用注解

@RepositoryDefinition(domainClass = User.class, idClass = Integer.class)
public interface UserRepository{
    //查找全部學生信息
    public List<User> findAll();
    //保存學生信息
    public void save(User user);
}

7:測試(在數據庫中添加數據並在測試類里面查詢)修改測試類com.gx.SpringData內容如下

package com.gx;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.gx.entity.User;
import com.gx.repository.UserRepository;

public class SpringData {
    //獲取上下文
    private ApplicationContext ctx = null;
    private UserRepository userRepository = null;
    @Before
    public void setup(){
        System.out.println("setup is working......");
        ctx = new ClassPathXmlApplicationContext("spring-data-beans.xml");
        userRepository = ctx.getBean(UserRepository.class);
    }
    @After
    public void destory(){
        ctx = null;
        System.out.println("destory is working......");
    }
    
    @Test
    public void testEntityManagerFctory(){
        
    }
    
    @Test
    public void findByName(){
        User user = userRepository.findByName("minuobaci");
        System.out.println(user);
    }
}

 8:測試結果

 

附:

查詢方法的定義和使用

UserRepository里面的方法的名字是遵循一定的規則的,不能隨便亂取

 對於按照方法命名規則來使用,有弊端:

1:方法名比較長

2:對於一些復雜的查詢很難實現

這個時候就使用查詢注解就好

只需要將@Query定義在Repository的方法上面就可以了,並且支持命名參數和索引參數的使用

 

 

查詢注解的使用

1:修改UserRepository為以下代碼

package com.gx.repository;

import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.RepositoryDefinition;

import com.gx.entity.User;

@RepositoryDefinition(domainClass = User.class, idClass = Integer.class)
public interface UserRepository{
    //查詢id最大的用戶的信息
    /*需要注意的是:
     * 1:方法名是自己隨便取的
     * 2:在Query里面的查詢語句里面的User表示的是類名而不是表名
     * 3:查詢所有不能使用 select * ,* 是不能被識別的,要查詢所有可以使用 select 別名
     */
    @Query("select u from User u where id=(select max(id) from User)")
    public User findMaxIdUser();
    
}

2:修改測試類

package com.gx;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.gx.entity.User;
import com.gx.repository.UserRepository;

public class SpringData {
    //獲取上下文
    private ApplicationContext ctx = null;
    private UserRepository userRepository = null;
    @Before
    public void setup(){
        System.out.println("setup is working......");
        ctx = new ClassPathXmlApplicationContext("spring-data-beans.xml");
        userRepository = ctx.getBean(UserRepository.class);
    }
    @After
    public void destory(){
        ctx = null;
        System.out.println("destory is working......");
    }
    
    @Test
    public void testFindMaxIdUser(){
        User user = userRepository.findMaxIdUser();
        System.out.println(user);
    }
}

 

 根據參數查詢

1:占位符

在UserRepository里面添加根據用戶姓名和年齡查詢的查詢方法findUserByMess

    /*
     * 這個地方的問號是占位符
     */
    @Query("select u from User u where name=?1 or age>?2")
    public List<User> findUserByMess(String name,Integer age);

測試方法findUserByMess

    @Test
    public void testFindUserByMess(){
        List<User> users = userRepository.findUserByMess("minuobaci", 12);
        for(User user:users){
            System.out.println(user);
        }
    }

測試結果

 

 

2:按照命名參數的方式

在UserRepository里面添加根據用戶姓名和年齡查詢的查詢方法findUserByMess2

    /*
     * 按照命名參數的方式
     */
    @Query("select u from User u where name=:username or age>:userage")
    public List<User> findUserByMess2(@Param("username")String name,@Param("userage")Integer age);

測試方法findUserByMess

@Test
    public void testFindUserByMess(){
        List<User> users = userRepository.findUserByMess2("minuobaci", 12);
        for(User user:users){
            System.out.println(user);
        }
    }

測試結果

 

 

根據參數查詢使用like

1:使用上面兩種方式實現like查詢

    /*
     *使用占位符的方式實現like 
     */
    @Query("select u from User u where name like ?1")
    public List<User> findBylike1(String name);
    
    /*
     *使用按照命名參數的方式實現like 
     */
    @Query("select u from User u where name like %:username%")
    public List<User> findBylike2(@Param("username")String name);

2:測試方法

    @Test
    public void testLike(){
        List<User> users1 = userRepository.findBylike1("minuobaci");
        System.out.println("這是測試使用占位符的方式實現like的測試結果");
        for(User user:users1){
            System.out.println(user);
        }
        List<User> users2 = userRepository.findBylike2("minuobaci");
        System.out.println("這是測試使用按照命名參數的方式實現like的測試結果");
        for(User user:users2){
            System.out.println(user);
        }
    }

3:測試結果

 

關於spring data的更新在 

http://www.cnblogs.com/minuobaci/p/7553118.html

 

在注解中使用原生的sql

1:在UserRepository里面添加count方法

    /* 在注解中使用原生的sql
     * nativeQuery是指能否支持原生態的查詢,默認是false
     * value里面的user指的是表名
     */
    @Query(nativeQuery=true,value="select count(1) from user")
    public int count();

2:測試

    @Test
    public void testNative(){
        System.out.println("總人數是:"+userRepository.count());
    }

3:測試結果

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM