参考链接:

Spring Data JPA - Reference Documentation

Spring Data JPA——参考文档 中文版

纯洁的微笑:http://www.ityouknow.com/

springboot(二):web综合开发 http://www.ityouknow.com/springboot/2016/02/03/springboot(%E4%BA%8C)-web%E7%BB%BC%E5%90%88%E5%BC%80%E5%8F%91.html 

spring boot(五):spring data jpa的使用 http://www.cnblogs.com/ityouknow/p/5891443.html

http://www.cnblogs.com/larryzeal/p/5799195.html

一、HelloWorld

1、application

@SpringBootApplication 等同于默认的属性的 @Configuration@EnableAutoConfiguration and @ComponentScan。 

@SpringBootApplication

由于大量项目都会在主要的配置类添加@Configuration,@EnableAutoConfiguration,@ComponentScan三个注解。

因此Spring Boot提供了@SpringBootApplication注解,该注解可以替代上面三个注解(使用Spring注解继承实现)。

  • @configuration注解在类上,声明是个配置bean,替代一个xml配置
  • @bean 注解在类上,声明这是个bean,代替一个bean配置<bean id="xxx" class="xxx"/>

另外两个

  • @ComponentScan

SpringBoot在写启动类的时候如果不使用@ComponentScan指明对象扫描范围,默认指扫描当前启动类所在的包里的对象,如果当前启动类没有包,则在启动时会报错:Your ApplicationContext is unlikely to start due to a @ComponentScan of the default package错误。

因为启动类不能直接放在main/java文件夹下,必须要建一个包把它放进去或者使用@ComponentScan指明要扫描的包。

  • @EnableAutoConfiguration

启用某个特性,会导入相关的配置注解。如:

@EnableTransactionManagement注释,它能够声明事务管理;

@EnableWebMvc注释,它能启用Spring MVC;

@EnableScheduling注释,它可以初始化一个调度器。 

参照

http://blog.csdn.net/chjttony/article/details/6286144

http://blog.csdn.net/xiaoyu411502/article/details/52770723

Application主类上配置的注解和包有关,默认指向该类所在的包。如:ComponentScan,EntityScan,SpringApplication注解

启动项目SpringApplication.run,启动Spring Boot项目最简单的方法就是执行下面的方法:

  • SpringApplication.run(Application.class, args); // 返回ApplicationContext对象,使用注解时返回的具体类型是AnnotationConfigApplicationContextAnnotationConfigEmbeddedWebApplicationContext,当支持web的时候是第二个。

除了上面这种方法外,还可以用下面的方法:

  • SpringApplication application = new SpringApplication(Application.class); application.run(args);

2、配置

3、配置

二、简单的rest+json支持

1、HelloSimpleController

2、HelloRestController

三、访问数据库

1、配置文件

1.1、数据库依赖

1.2、数据源

spring.jpa.properties.hibernate.hbm2ddl.auto是hibernate的配置属性,其主要作用是:自动创建、更新、验证数据库表结构。该参数的几种配置如下:

  • create:每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。
  • create-drop:每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。
  • update:最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等应用第一次运行起来后才会。
  • validate:每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。

2、编写代码

2.1、pojo

2.2、JPA库

使用jpa来持久化数据

Spring Boot 可以自动配置嵌入式的数据库,包括 H2、HSQL 和 Derby,你不需要配置数据库链接的 url,只需要添加相关的依赖即可。

另外,你还需要依赖 spring-jdbc,在本例中,我们是引入了对 spring-boot-starter-data-jpa 的依赖。

如果你想使用其他类型的数据库,则需要配置 spring.datasource.* 属性,一个示例是在 application.properties 中配置如下属性:

spring.datasource.url=jdbc:mysql://localhost/test
spring.datasource.username=dbuser
spring.datasource.password=dbpass
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

创建 src/main/resources/application.properties 文件,修改 JPA 相关配置,如:

spring.jpa.hibernate.ddl-auto=create-drop

注意:

SpringApplication 会在以下路径查找 application.properties 并加载该文件:

  • /config 目录下
  • 当前目录
  • classpath 中 /config 包下
  • classpath 根路径下

在Spring-data-jpa中,只需要编写类似上面这样的接口就可实现数据访问。不再像我们以往编写了接口时候还需要自己编写接口实现类,直接减少了我们的文件清单。

通过查看JpaRepository接口的API文档,可以看到该接口本身已经实现了创建(save)、更新(save)、删除(delete)、查询(findAll、findOne)等基本操作的函数,因此对于这些基础操作的数据访问就不需要开发者再自己定义。

实际开发中,JpaRepository接口定义的接口往往还不够或者性能不够优化,我们可以进一步实现更复杂一些的查询或操作。

上面例子中,我们可以看到下面两个函数:

  • User findByName(String name)
  • User findByNameAndAge(String name, Integer age)

它们分别实现了按name查询User实体和按name和age查询User实体,可以看到我们这里没有任何类SQL语句就完成了两个条件查询方法。这就是Spring-data-jpa的一大特性:通过解析方法名创建查询。

2.3、Controller

3、测试准备

3.1、启动应用,自动建表

3.2、对应的数据结构

3.3、准备数据

DELETE FROM dept;
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(101,'NAME-101','DESC-101',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(102,'NAME-102','DESC-102',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(103,'NAME-103','DESC-103',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(104,'NAME-104','DESC-104',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(105,'NAME-105','DESC-105',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(106,'NAME-106','DESC-106',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(107,'NAME-107','DESC-107',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(108,'NAME-108','DESC-108',0,SYSDATE(),SYSDATE());
INSERT INTO dept (ID,NAME,DESCRIPTION,IN_USE,CREATE_DATE,UPDATE_DATE) VALUES(109,'NAME-109','DESC-109',0,SYSDATE(),SYSDATE());
COMMIT;
SELECT * FROM dept;

SELECT 101,'NAME101',TRUE,SYSDATE(),SYSDATE();

4、测试rest方法

4.1、get 查询所有 (无body体)

[
{
"id": 101,
"name": "NAME-101",
"description": "DESC-101",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 102,
"name": "NAME-102",
"description": "DESC-102",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 103,
"name": "NAME-103",
"description": "DESC-103",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 104,
"name": "NAME-104",
"description": "DESC-104",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 105,
"name": "NAME-105",
"description": "DESC-105",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 106,
"name": "NAME-106",
"description": "DESC-106",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 107,
"name": "NAME-107",
"description": "DESC-107",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 108,
"name": "NAME-108",
"description": "DESC-108",
"inUse": false,
"createDate": 1505801308000,
"updateDate": 1505801308000
},
{
"id": 109,
"name": "NAME-109",
"description": "DESC-109",
"inUse": false,
"createDate": 1505801309000,
"updateDate": 1505801309000
}
]

4.2、post 新增记录(json-body)

4.3、delete 删除记录(无body体)

4.4、put 更新记录(有body体)

SpringBoot的HelloWorld 应用及解释的更多相关文章

  1. [一]SpringBoot 之 HelloWorld

    (1)新建一个Maven Java工程 (2)在pom.xml文件中添加Spring BootMaven依赖 2.1在pom.xml中引入spring-boot-start-parent spring ...

  2. eclipse springboot运行helloworld错误: 找不到或无法加载主类 xxx.xxx.xxx

    这个错误,在网上搜找了好久,说是什么jar包冲突,什么环境配置,我经过验证均是正确的,javac java java -version 都没问题,环境变量也OK,各种解释均没有能够解决我的问题,最后好 ...

  3. springboot之HelloWorld

    简介 为了简化开发Spring的复杂度,Spring提供了SpringBoot可以快速开发一个应用,这里就简单介绍下SpringBoot如何快速开发一个J2EE应用 HelloWorld 首先在gra ...

  4. SpringBoot学习helloworld

    这几天开始学习springBoot记录一下(Hello World) pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0 ...

  5. SpringBoot入门学习(一): Idea 创建 SpringBoot 的 HelloWorld

    创建项目: 项目结构: 程序启动入口: 正式开始: package com.example.demo; import org.springframework.boot.SpringApplicatio ...

  6. redis整合springboot的helloworld

    引入依赖 compile 'org.springframework.boot:spring-boot-starter-data-redis' 使用redis有两种方法 1.Jedis Jedis je ...

  7. SpringBoot——探究HelloWorld【三】

    前言 前面我们写了helloworld的一个,这里我们对他进行分析 探究 那么下面就开始我们的探究之旅吧,首先从POM文件来,在POM文件中我们导入了项目所需要的依赖 POM文件 父项目 <pa ...

  8. spring-boot的helloWorld详解

    1.运行环境 开发工具:intellij idea JDK版本:1.8 项目管理工具:Maven 3.2.5 2.Maven Plugin管理 pom.xml配置代码: <project xml ...

  9. SpringBoot的 HelloWorld

    SpringBoot HelloWorld 功能需求 ​ 浏览器发送hello请求,服务器接收请求并处理,相应HelloWorld字符串 1.创建一个maven工程:(jar) 2.导入SpringB ...

随机推荐

  1. Python爬虫获取异步加载站点pexels并下载图片(Python爬虫实战3)

    1. 异步加载爬虫 对于静态页面爬虫很容易获取到站点的数据内容,然而静态页面需要全量加载站点的所有数据,对于网站的访问和带宽是巨大的挑战,对于高并发和大访问访问量的站点来说,需要使用AJAX相关的技术 ...

  2. MacOS中升级openssl

    MacOS中升级openssl   ➜  ~ brew instal openssl 使用情况中始终发现,openssl并没有真正升级   在/usr/local/Cellar/openssl/目录中 ...

  3. maven导入多模块项目

    maven导入多模块项目   一.SVN上Maven多模块项目结构 使用eclipse导入SVN上的Maven多模块项目 Maven多模块项目所在SVN目录 二.eclipse通过SVN导入到工作空间 ...

  4. Java中动态代理工作流程

    当谈到动态代理就会想到接口,因为接口是一种规范,动态代理对象通过接口便会很清楚地知道他的实现类(被代理对象)是何种类型的(即有哪些方法).Now,然我们来开始编写一个例子来了解动态代理的全过程: 第一 ...

  5. C语言第八次博客作业--字符数组

    一.PTA实验作业 题目1:查验身份证 1. 本题PTA提交列表 2. 设计思路 定义i,flag=1,z,m[11],a[19] 输入次数n for i=1 to n+1 gets(a) 加权求和在 ...

  6. javascript数组Array强大的splice()方法

    javascript的Array数组提供了强大的splice()方法, 用于对数组元素的增删改 1.删除-用于删除元素,两个参数,第一个参数(要删除第一项的位置),第二个参数(要删除的项数) 删除: ...

  7. 笔记:Spring Cloud Hystrix Command属性

    主要用来控制 HystrixCommand 命令的行为,主要有下面5种类型的属性配置: execution配置 该配置前缀为 hystrix.command.default execution.iso ...

  8. express+mysqle

    var mysql=require('mysql'); var connection=mysql.createConnection({ host:'',//地址 port:'',//端口号 user: ...

  9. webpack-dev-server 搭建本地服务以及浏览器实时刷新

    一.概述开发项目中为了保证上线,开发项目是都需要使用localhost进行开发,以前的做法就是本地搭建Apache或者Tomcat服务器.有的前端开发人员 对服务器的搭建和配置并不熟悉,这个时候需要后 ...

  10. ngix_http_stub_status_module

    1.ngx_http_stub_status_module 是一个 Nginx 的内置 HTTP 模块,该模块可以提供 Nginx 的状态信息.默认情况下这个模块是不被编译进来的,所以在编译 Ngin ...