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:測試結果