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:测试结果

使用Maven开发一个简单的SpringData的更多相关文章

  1. 如何开发一个简单的HTML5 Canvas 小游戏

    原文:How to make a simple HTML5 Canvas game 想要快速上手HTML5 Canvas小游戏开发?下面通过一个例子来进行手把手教学.(如果你怀疑我的资历, A Wiz ...

  2. 重新想象 Windows 8 Store Apps (64) - 后台任务: 开发一个简单的后台任务

    [源码下载] 重新想象 Windows 8 Store Apps (64) - 后台任务: 开发一个简单的后台任务 作者:webabcd 介绍重新想象 Windows 8 Store Apps 之 后 ...

  3. Cocos2d-x-Lua 开发一个简单的游戏(记数字步进白色块状)

    Cocos2d-x-Lua 开发一个简单的游戏(记数字步进白色块状) 本篇博客来给大家介绍怎样使用Lua这门语言来开发一个简单的小游戏-记数字踩白块. 游戏的流程是这种:在界面上生成5个数1~5字并显 ...

  4. Python开发一个简单的BBS论坛

    项目:开发一个简单的BBS论坛 需求: 整体参考“抽屉新热榜” + “虎嗅网” 实现不同论坛版块 帖子列表展示 帖子评论数.点赞数展示 在线用户展示 允许登录用户发贴.评论.点赞 允许上传文件 帖子可 ...

  5. 作业1开发一个简单的python计算器

    开发一个简单的python计算器 实现加减乘除及拓号优先级解析 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568 ...

  6. django学习-11.开发一个简单的醉得意菜单和人均支付金额查询页面

    1.前言 刚好最近跟技术部门的[产品人员+UI人员+测试人员],组成了一桌可以去公司楼下醉得意餐厅吃饭的小team. 所以为了实现这些主要点餐功能: 提高每天中午点餐效率,把点餐时间由20分钟优化为1 ...

  7. 自己动手模拟开发一个简单的Web服务器

    开篇:每当我们将开发好的ASP.NET网站部署到IIS服务器中,在浏览器正常浏览页面时,可曾想过Web服务器是怎么工作的,其原理是什么?“纸上得来终觉浅,绝知此事要躬行”,于是我们自己模拟一个简单的W ...

  8. 【UI插件】开发一个简单日历插件(上)

    前言 最近开始整理我们的单页应用框架了,虽然可能比不上MVVM模式的开发效率,也可能没有Backbone框架模块清晰,但是好歹也是自己开发出来 而且也用于了这么多频道的东西,如果没有总结,没有整理,没 ...

  9. 30 分钟开发一个简单的 watchOS 2 app <oneVcat>

    Apple Watch 和 watchOS 第一代产品只允许用户在 iPhone 设备上进行计算,然后将结果传输到手表上进行显示.在这个框架下,手表充当的功能在很大程度上只是手机的另一块小一些的显示器 ...

随机推荐

  1. 洛谷P5280 [ZJOI2019]线段树

      https://www.luogu.org/problemnew/show/P5280 省选的时候后一半时间开这题,想了接近两个小时的各种假做法,之后想的做法已经接近正解了,但是有一些细节问题理不 ...

  2. Django基础(2)--模板自定义标签和过滤器,模板继承 (extend),Django的模型层-ORM简介

    没整理完 昨日回顾: 视图函数: request对象 request.path 请求路径 request.GET GET请求数据 QueryDict {} request.POST POST请求数据 ...

  3. GUI的最终选择 Tkinter(三):Checkbutton组件和Radiobutton组件、LabelFrame组件

    Checkbutton组件 Checkbutton组件就是常见的多选按钮,而Radiobutton则是单选按钮 from tkinter import * root = Tk() v = IntVar ...

  4. HDU 4622 Reincarnation Hash解法详解

    今天想学字符串hash是怎么弄的.就看到了这题模板题 http://acm.hdu.edu.cn/showproblem.php?pid=4622 刚开始当然不懂啦,然后就上网搜解法.很多都是什么后缀 ...

  5. (转)Linux: dirname、basename命令详解

    Linux: dirname.basename命令详解 原文:http://blog.sina.com.cn/s/blog_3f63916f010143vo.html 一.dirname指令 1.功能 ...

  6. 《从0到1学习Flink》—— Apache Flink 介绍

    前言 Flink 是一种流式计算框架,为什么我会接触到 Flink 呢?因为我目前在负责的是监控平台的告警部分,负责采集到的监控数据会直接往 kafka 里塞,然后告警这边需要从 kafka topi ...

  7. Asp.NET MVC+WebAPI跨域调用

    使用jQuery调用WebApi有时会遇到跨域的问题,今天介绍一种可以简单解决跨域问题的方法. 当我们跨域请求WebAPI的时候会提示以下信息: XMLHttpRequest cannot load ...

  8. JVM虚拟机 - Class类文件结构

    概述 Class文件是一组以8位字节为基础单位的二进制流,各个数据项目严格按照顺序紧凑地排列在Class文件之中,中间没有添加任何分隔符,这使得整个Class文件中存储的内容几乎都是程序运行的必要数据 ...

  9. 从零开始的全栈工程师——js篇2.3

    自加和自减 =赋值运算 他的顺序是从右往左 从后往前 var a=12; 声明一个变量并将12赋值给aa=a+2; 将a+2赋值给a简写a+=3; a=a+3a+=1; a++ 在自己原有的基础上加1 ...

  10. redis空间键详解

    前言 redis的空间键通知是在2.8.0版本以后加入的,客户端通过发布订阅的方式,订阅某个频道,接收通过某种方式影响redis中数据的事件. 目录: 1.空间键事件分类 2.如何启用redis的空间 ...