SpringBoot入门基础

目录

SpringBoot入门 (一) HelloWorld. 2

一 什么是springboot 1

二 入门实例... 1

SpringBoot入门 (二) 属性文件读取... 16

一 自定义属性... 15

二 自定义属性配置文件... 18

SpringBoot入门 (三) 日志配置... 21

日志格式及内容... 21

日志输出... 22

输出文件... 22

集成log4j 23

SpringBoot入门 (四) 数据库访问之JdbcTemplate. 29

一 JDBC回顾... 28

二 JdbcTemplate使用示例... 29

三 测试,使用Junit Test 34

四 连接池配置... 36

SpringBoot入门 (五) 数据库访问之spring data jpa. 39

一 什么是Spring Data JPA.. 38

二 简单示例... 38

三 测试... 42

SpringBoot入门 (六) 数据库访问之Mybatis. 46

一 什么是Mybatis. 46

二 SpringBoot集成Mybatis. 47

三 测试... 51

SpringBoot入门 (七) Redis访问操作... 53

一 什么是Redis. 53

二 SpringBoot集成Redis. 54

三 测试... 55

SpringBoot入门 (八) Cache使用... 60

一 为什么要使用缓存... 59

二 使用Cache. 60

1 @Cacheable. 61

2 @CachePut 62

3 CacheEvict 63

SpringBoot入门 (九) MQ使用... 65

一 什么是MQ.. 64

二 SpringBoot集成Active MQ.. 65

SpringBoot入门 (十) 发送邮件... 73

一 邮件发送过程... 72

二 发送邮件示例... 73

SpringBoot入门 (十一) 数据校验... 81

一 什么是数据校验... 80

二 使用示例... 82

SpringBoot入门 (十二) 定时任务... 88

一 SpringBoot 提供的定时任务... 87

二 SpringBoot集成Quartz. 90

 

返回目录

下一篇

SpringBoot入门 (一) HelloWorld

一 什么是springboot

  springboot是一个全新的框架,它设计的目的简化spring项目的初始环境的搭建和开发,主要有以下几个特点:

  1、简化初始配置 ,可与主流框架集成;

  2、内置Servlet容器,无需在打War包;

  3、使用了Starter(启动器)管理依赖并版本控制;

  4、大量的自动配置,简化开发,方便集成第三方;

  5、提供准生产环境运行时的监控,如指标,健康,外部配置等;

  6、无需XML配置,减少冗余代码 。

  未使用springboot时,如果我们要搭建一个springweb项目环境,我们需要配置web.xml及各种xml的配置文件来集成其他第三方的框架,而这些springboot已经帮我们做了集成,我们不再需要去配置。

二 入门实例

  创建springboot项目有2中方式,1种是通过ide来创建,一种是官方网站创建(https://start.spring.io创建完成后会将工程下载到本地)然后导入ide即可,本文我们通过idea创建项目。

  1 在idea的工具栏 file-->new project 如下图

 

会弹出选择工程类型的框,如下图

 

这个时候我们有2种选择,一种是使用Spring Initializr创建,一种是使用Maven或者Gradle创建。这两种方式的不同的地方是使用方法二创建的是空项目,我们需要自己去修改添加所需要的依赖,方式一在创建的过程中,我们可以在ide中直接选择需要的依赖且会生成一个项目的根启动类。本文我们使用Spring Initializr来创建项目。点击上图的Next

 

输入Group、Artifact、Package的对应的信息,再点击next

 

这是我们可以选择我们的项目要运行的springboot的版本和需要的依赖包(本文我们只选择依赖web),然后点击Next

 

这是弹框会显示我们项目的名称及项目的路径,点击Finish。初始时会下载springboot默认依赖的一些jar包,需要一会时间,我们等待它下载完成。之后我们可以看到项目的结构

 

pom.xml内容如下,2.0.8版本不是一个发布版本,在我们的实际项目中,最好还是要引用release版本的。

 

         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

    4.0.0

 

    org.allen.demo

    springboot-helloworld

    0.0.1-SNAPSHOT

    jar

 

    springboot-helloworld

    Demo project for Spring Boot

 

   

        org.springframework.boot

        spring-boot-starter-parent

        2.0.8

       

   

 

   

        UTF-8

        UTF-8

        1.8

   

 

   

       

            org.springframework.boot

            spring-boot-starter-web

       

 

       

            org.springframework.boot

            spring-boot-starter-test

            test

       

   

 

   

       

           

                org.springframework.boot

                spring-boot-maven-plugin

           

       

   

 

 

 

生成的启动类,一个可执行的main方法。

 

package org.wl.demo;

 

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

 

@SpringBootApplication

public class HelloWorldApplication {

 

    public static void main(String[] args) {

        SpringApplication.run(HelloWorldApplication.class, args);

    }

}

 

默认在类上边使用了@SpringBootApplication注解,这个注解是一个符合注解,相当于同时使用

@SpringBootConfiguration  指定类为配置类

@EnableAutoConfiguration  开启自动配置

@ComponentScan 指定扫描路径

下来创建一个可以访问的控制器,使用@RestController注解,它是一个复合注解,相当于同时使用了@Controller和@ResponseBody注解

 

package org.wl.demo.web;

 

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;

 

@RestController

public class HelloController {

 

    @RequestMapping("/hello")

    public String hello(){

        return "hello world";

    }

 

}

 

执行main方法,启动项目,在控台可可以看到启动的日志信息

[           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8080 (http) with context path ''

[           main] org.wl.demo.HelloWorldApplication     : Started HelloWorldApplication in 3.591 seconds (JVM running for 4.784)

内嵌的tomcat服务器已经启动,启动端口是8080,更路径是'',我们访问控制器的hello方法

 

这样一个web项目环境就搭建成功了,使用起来还是很简单方便的。

在上边的日志信息中,默认启动端口是8080,访问根路径是‘’,如果我们希望修改的话也是可以的,只需要在application.properties中修改

修改端口,从默认的8080修改为8090

server.port=8090

修改根路径 修改前是‘’,修改后为‘/helloworld’

server.servlet.context-path=/helloWorld

 

 

返回目录

上一篇

下一篇

SpringBoot入门 (二) 属性文件读取

  在上一篇中介绍了在idea中创建springboot工程及使用web工程输出“helloworld”到前端页面,本文学习在springboot工程中读取属性文件中的属性值。

一 自定义属性

  在application.properties文件中添加属性配置项

 myapp.name=helloworld 

  可以使用@Value 注解来读取,在之前的helloworld工程的控制器中添加属性并读取,如下

 

@RestController

public class HelloController {

 

    @Value("${myapp.name}")

    private String name;

 

    @RequestMapping("/hello")

    public String hello(){

        System.out.println("myapp name :" + name);

        return "helloworld";

    }

 

}

 

@Value 注解会去application.properties文件中配置属性为myapp.name的属性,并将值赋值给name属性。访问hello方法,可以看到控制台上打印出来的信息

 

  自定义的属性比较少时使用@Value读取还是比较方便的,如果我们的属性比较多的时候,比如我们要读取数据库连接池配置的很多的属性值,再这样读取的话,就显得不是很美观了。这种情况我们一般定义一个对象,把属性字段作为对象的属性来接收,在属性文件中在增加一个属性

 myapp.age=2

  我们定义一个对象MyAppProperties来接收属性值

 

@Component

@ConfigurationProperties(prefix = "myapp")

public class MyAppProperties {

 

    private String name;

    private int age;

 

    @Override

    public String toString() {

        return "MyAppProperties{" +

                "name='" + name + '\'' +

                ", age=" + age +

                '}';

    }

 

    //省略getter和setter方法

}

 

@Component 表示指定当前类为实例,以便可以在spring中使用
@ConfigurationProperties(prefix = "myapp") 表示把application中的myapp开头的属性自动赋值给当前对象的属性,比如把myapp.name的值赋值给name属性,访问hello方法可以看到。

二 自定义属性配置文件

  有的时候,我们需要把自己的属性配置信息写在自己的配置文件中,以便和系统的application.properties分开,我们可以在resources目录下新建自己的属性文件my.properties,并添加属性
my.name=helloworld2

my.age=22            

 

定义读取属性的对象类,使用 @PropertySource("classpath:my.properties") 来指定我们当前类要读取的属性文件

 

@Component

@PropertySource("classpath:my.properties")

@ConfigurationProperties(prefix = "my")

public class MyAppProperties2 {

 

    private String name;

    private int age;

 

    @Override

    public String toString() {

        return "MyAppProperties2{" +

                "name='" + name + '\'' +

                ", age=" + age +

                '}';

    }

 

    // 省略getter和setter方法

}

 

  修改控制器hello方法测试

 

@RestController

public class HelloController {

 

    @Resource

    private MyAppProperties myAppProperties;

    @Resource

    private MyAppProperties2 myAppProperties2;

 

    @RequestMapping("/hello")

    public String hello(){

        System.out.println(myAppProperties.toString());

        System.out.println(myAppProperties2.toString());

        return "helloworld";

    }

 

}

 

  访问hello方法,可以看到控制台输出的打印信息

 

 

 

返回目录

上一篇

下一篇

SpringBoot入门 (三) 日志配置

上一篇博文记录了再springboot项目中读取属性文件中配置的属性,本文学习在springboot项目中记录日志。

  日志记录在项目中是很常见的一个功能了,对排查问题有很大帮助,也可以做分类分析及统计。SpringBoot内部使用的是Commons Logging做日志的记录,但是对其他的日志框架也提供了默认的配置,如:Java util Logging,Log4j2,Logback,每一种情况下日志记录器都预先配置为使用控制台输出和可选的文件输出。

日志格式及内容

  如果我们的SpringBoot项目使用的是Starters启动器,默认使用LogBack做日志记录。如我们启动项目时在控制台上看到的

 

输出的信息有以下几点
日期和时间:精确到毫秒,如 2019-01-24 14:03:14.260

日志级别:日志级别有ERROR,WARN,INFO,DEBUG,TRACE,如上边的INFO

进程号:如上边的 10348

分割线:如上边的 ---

线程名:如上边用[]括起来的

日志名:一般使用的是代码的类名

日志信息:我们在代码中要输出的内容

日志输出

  Spring Boot中默认配置了ERROR、WARN和INFO级别的日志输出到控制台,我们也是可以修改的日志级别的,比如我们修改为debug级别,有两种方式

1 使用命令 $ java -jar myapp.jar --debug 

2 在application.properties中添加配置debug=true 开启debug,此配置只会对核心Logger(如内嵌的tomcat容器、hibernate、spring)有效,但是我们自己应用的日志并不会输出为DEBUG级别,需要自己配置,如 logger.level.root=debug

日志级别

  可以通过logger.level.*=LEVEL来改变对应日志级别,如

1

2

3

4

5

6

7

8

logging.level.root=warn

logging.level.org.springframework.web=info

logging.level.org.hibernate=error

 

######修改mubatis日志级别

logging.level.org.mybatis=info

#mapper接口为debug级别

logging.level.mybatis mapper接口所在包=debug

输出文件

  SpringBoot默认只在控制台输出日志信息,如果想把日志信息写入文件中记录,需要在application.properties中配置,如

1

2

3

4

5

6

7

8

##文件存放路径

logging.path=/usr/local/log

##写入的文件

logging.file=myapp.log

##日志文件大小,超过大小时会在新的文件中记录

logging.file.max-size=10Mb

##日志保存时间 天

logging.file.max-history=15

集成log4j

  SpringBoot在高版本中已经不支持log4j了,支持的是log4j2。在pom.xml中引入需要的log4j2的jar包

 

            org.springframework.boot

            spring-boot-starter-web

           

               

                    org.springframework.boot

                    spring-boot-starter-logging

               

           

       

 

       

            org.springframework.boot

            spring-boot-starter-log4j2

       

 

由于web依赖包中已经有了log的依赖,所以我们选去掉web中的log依赖,避免jar包冲突。

  然后配置log4j2的属性,在官方文档中可以看到集成的日志文件的命名如下

 

  在resources目录下创建一个log4j2-spring.xml文件

 

   

       

        %d{yyyy-MM-dd HH:mm:ss,SSS} |-%-5level [%thread] %c [%L] -| %msg%n

   

   

       

       

           

       

       

       

           

                ${PATTERN}

           

           

               

           

       

   

   

       

           
       

           

       

       

       

           

       

   

 

  正式项目中,我们需要对上述xml文件中的配置信息做些修改。写一个控制器访问,看看输出的信息

 

@RestController

public class HelloController {

 

    private static final Logger logger = LoggerFactory.getLogger(HelloController.class);

   

    @RequestMapping("/hello")

    public String hello(){

        logger.info("使用log4j输出日志!");

        return "helloworld";

    }

 

}

 

控制台和生成的log文件中输出的信息一致

 

 

 

 

返回目录

上一篇

下一篇

SpringBoot入门 (四) 数据库访问之JdbcTemplate

JDBC回顾

  最早是在上学时接触的使用JDBC访问数据库,主要有以下几个步骤:

1 加载驱动 Class.forName(Driver)

2 获取数据库连接 conn = DriverManager.getConnection(url, user,password)

3 创建一个statement对象来访问操作数据库 statement = conn.createStatement();

4 执行SQL,访问操作数据库 rs = statement.execute(sql)

5 得到结果集,业务处理

6 关闭连接,释放资源 statement.close(); conn.close();

使用jdbc访问并操作数据库时比较麻烦,后来也做了一定的封装,主要是对statement的创建前和sql执行后进行的封装。

二 JdbcTemplate使用示例

  目前我们使用的主流的开源的数据库访问框架主要有Hibernate,Mybatis,SpringJdbc。SpringJdbc时spring对JDBC封装后的一个ORM框架,JdbcTemplate就是SpringJdbc对外提供的一个访问数据库的接口类,我们通过它可以很容易的实现数据库的访问操作。但是需要我们自己根据业务手写相关的SQl,然后执行。

在spring boot项目中引入依赖,本文练习中使用的时MySql数据库

1

2

3

4

5

6

7

8

9

       org.springframework.boot

       spring-boot-starter-jdbc

         

  

     mysql

     mysql-connector-java

  

 

 

在application.properties中配置数据库连接相关信息

1

2

3

4

5

6

7

8

9

#数据库配置

#连接

spring.datasource.url=jdbc:mysql://localhost:3306/test

#账号

spring.datasource.username=root

#密码

spring.datasource.password=123456

#驱动

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

完成以上配后,在启动springboot项目时,会自动把数据源信息注入到JdbcTemplate中,我们只需要在使用的地方注入JdbcTemplate就可以了

定义要操作数据库的相关方法接口

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

public interface UserDao {

 

    /**

     * 添加用户

     */

    int insert(UserInfo user);

 

    /**

     * 根据ID删除用户

     */

    int delete(Long id);

 

    /**

     * 修改用户

     */

    int update(UserInfo user);

 

    /**

     * 根据ID查询用户

     */

    UserInfo queryById(Long id);

 

    /**

     * 查询所有用户

     * @return

     */

    List queryAll();

 

    /**

     * 分页查询用户

     * @param start 开始位置

     * @param size 要查询的数据条数

     * @return

     */

    List pagedQuery(int start, int size);

 

}

1

接口的实现

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

@Service

public class UserDaoImpl implements UserDao {

 

    @Autowired

    private JdbcTemplate jdbcTemplate;

 

    @Override

    public int insert(UserInfo user) {

      String insertSql = "insert into t_user(name, age) values(?, ?)";

      return jdbcTemplate.update(insertSql, user.getName(), user.getAge());

    }

 

    @Override

    public int delete(Long id) {

        String deleteSql = "delete from t_user where id = ?";

        return jdbcTemplate.update(deleteSql, id);

    }

 

    @Override

    public int update(UserInfo user) {

        String updateSql = "update t_user set name = ?, age = ? where id = ?";

        return jdbcTemplate.update(updateSql, user.getName(), user.getAge(), user.getId());

    }

 

    @Override

    public UserInfo queryById(Long id) {

        String sql = "select * from t_user where id = ?";

        return jdbcTemplate.queryForObject(sql, new Object[]{id}, new BeanPropertyRowMapper(UserInfo.class));

    }

 

    @Override

    public List queryAll() {

        String sql = "select * from t_user";

        return jdbcTemplate.query(sql, new BeanPropertyRowMapper(UserInfo.class));

    }

 

    @Override

    public List pagedQuery(int start, int size) {

        String sql = "select * from t_user limit ?, ?";

        return jdbcTemplate.query(sql, new Object[]{start, size}, new BeanPropertyRowMapper(UserInfo.class));

    }

}

 

 

可以看到,使用JdbcTemplate时我们完全省去了使用JDBC时的创建连接,释放资源等操作。不同数据库的分页查询不一样,MySql中用的limit关键字,第一个参数代表获取数据的起点,第二个是要查询的数量,如:limit 5,5  我们查询出来的是第6行到10行 共5条数据

测试,使用Junit Test

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

@RunWith(SpringRunner.class)

@SpringBootTest

public class SpringbootJdbctemplateApplicationTests {

 

    @Autowired

    private UserDaoImpl userDaoImpl;

 

    @Test

    public void testInsert(){

        UserInfo user = new UserInfo("kg", 21);

        userDaoImpl.insert(user);

    }

 

    @Test

    public void testDelete(){

        long id = 2;

        userDaoImpl.delete(id);

    }

 

    @Test

    public void testUpdate(){

        long id = 1;

        UserInfo user = new UserInfo();

        user.setId(id);

        user.setName("kobe");

        user.setAge(3);

        userDaoImpl.update(user);

    }

 

    @Test

    public void testQueryById(){

        long id = 1;

        UserInfo user = userDaoImpl.queryById(id);

    }

 

    @Test

    public void testQueryAll(){

        List list = userDaoImpl.queryAll();

    }

 

    @Test

    public void testPagedQuery(){

        List list = userDaoImpl.pagedQuery(1, 2);

    }

}

在启动项目时,可以看到在控制台上输出的日志信息中有以下内容

 

连接池配置

  在我们没有配置数据库连接池时,springboot默认给我们提供的Hikari连接池。如果我们像使用其他的,我们可以自己配置,比如我们想使用阿里的Druid连接池,我们需要引入依赖

1

2

3

4

5

            com.alibaba

            druid

            1.1.10

        

为了测试方便,我这里直接用@Value注解来获取配置信息

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

@SpringBootConfiguration

public class DataSourceConfig {

 

    @Value("${spring.datasource.driver-class-name}")

    private String DRIVER;

    @Value("${spring.datasource.url}")

    private String URL;

    @Value("${spring.datasource.username}")

    private String USER;

    @Value("${spring.datasource.password}")

    private String PASSWORD;

 

    @Bean

    public JdbcTemplate jdbcTemplate(){

        JdbcTemplate jdbcTemplate = new JdbcTemplate();

        jdbcTemplate.setDataSource(dataSource());

        return jdbcTemplate;

    }

 

    @Bean

    public DataSource dataSource(){

        System.out.println("初始化数据源start。。。");

        DruidDataSource dataSource = new DruidDataSource();

        dataSource.setDriverClassName(DRIVER);

        dataSource.setUrl(URL);

        dataSource.setUsername(USER);

        dataSource.setPassword(PASSWORD);

        //连接池的其他的属性。。。

        dataSource.setMaxActive(5);

        //...

        System.out.println("初始化数据源end。。。");

        return dataSource;

    }

 

}

 @SpringBootConfiguration 这个注解说明当前类是一个配置类,需要被特殊处理,在扫描时发现有@Bean 注解,会把当前方法返回的类Bean注入的容器中,方法名会别标记为注入的Bean的别名,如上JdbcTemplate使用的DataSource就从默认的Hikari修改为Druid了,启动项目可以看到控制台日志信息

 

 

 

返回目录

上一篇

下一篇

SpringBoot入门 (五) 数据库访问之spring data jpa

本文记录学习使用spring data jpa访问数据库

什么是Spring Data JPA

  JPA(Java Persistence API)是Sun官方提出的Java持久化规范。它为Java开发人员提供了一种对象、关联映射工具来管理Java应用中的关系数据。主要是为了简化现有的持久化开发工作和整合ORM技术,对不同的ORM框架提供统一的规范标准。

  Spring Data JPA 是Spring基于Hibernate框架和JPA(Java Persistence API)规范的基础上封装的一套JPA应用框架,它提供了增、删、改、查等一些常用得方法供开发者调用,可以轻松实现实现对数据的访问和操作。

简单示例

  要使用spring data jpa,我们首先需要在pom.xml中引入所需要的依赖jar包

1

2

3

4

5

6

7

8

9

  org.springframework.boot

      spring-boot-starter-data-jpa

    

        

          mysql

          mysql-connector-java

        

  在application.properties文件配置数据源连接信息

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

#驱动

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

spring.datasource.url=jdbc:mysql://localhost:3306/test

#用户

spring.datasource.username=root

#密码

spring.datasource.password=123456

#ddl create:不论数据库表有没有都是创建,update:当表存在时更新,不存在是创建

spring.jpa.properties.hibernate.hbm2ddl.auto=update

#方言

spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect

#输出SQL

spring.jpa.show-sql=true

#对SQL格式化

spring.jpa.properties.hibernate.format_sql=true

   创建一个实体对象,完成与数据库表之间的映射

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

@Entity

@Table(name="t_user")

public class UserInfo {

 

    @Id

    @GeneratedValue(strategy = GenerationType.AUTO)

    private Long id;

    @Column(name = "name", nullable = true, length = 30)

    private String name;

    @Column(name="age", nullable = true, length = 3)

    private Integer age;

 

    public UserInfo() {

    }

 

    public UserInfo(String name, Integer age) {

        this.name = name;

        this.age = age;

    }

 

    @Override

    public String toString() {

        return "UserInfo{" +

                "id=" + id +

                ", name='" + name + '\'' +

                ", age=" + age +

                '}';

    }

 

    //省略getter和setter

}

@Entity 说明当前类为一个实体类,默认属性name可以不输入,默认就是当前类名
@Table(name="t_user") 说明当前类映射的数据库表是t_user
@Id 说明该字段是表的主键
@GeneratedValue(strategy = GenerationType.AUTO) 说明主键的生成策略是 GenerationType.*,*有AUTO、INDENTITY、SEQUENCE 和 TABLE可供选择
@Column(name = "name", nullable = true, length = 30) 说明当前字段在数据库表中对应的列属性,name:表中的列名,nullable:允许为空,length:长度不超过30

  前边已经说过了,Spring Data JPA 已经给我们提供了具体的接口供调用,所以只需要继承他的方法来使用就可以了,创建接口并继承JpaRepository

1

2

3

public interface UserRepository extends JpaRepository {

}

 

  在IDEA中打开类图(如上图),可以看到我们继承的JpaRepository 通过继承关系已经有了增删该查(CrudRepository)和分页排序(PagingAndSortingRepository),所以我们的UserRspository也就有了对应的方法

测试 

  使用Junit做个简单的测试

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

@RunWith(SpringRunner.class)

@SpringBootTest

public class JpaApplicationTests {

 

    @Resource

    private UserRepository userRepository;

 

    /**

     * 保存用户信息

     */

    @Test

    public void save() {

        UserInfo user = new UserInfo("卢俊义", 3);

        userRepository.save(user);

    }

 

    /**

     * 根据ID删除

     */

    @Test

    public void delete() {

        long id = 3;

        userRepository.deleteById(id);

    }

 

    /**

     * 修改

     */

    @Test

    public void update() {

        UserInfo user = new UserInfo();

        user.setId(Long.valueOf(3));

        user.setName("老卢");

        user.setAge(5);

        userRepository.saveAndFlush(user);

    }

 

    /**

     * 根据ID查询

     */

    @Test

    public void selectById() {

        long id = 3;

        UserInfo user = userRepository.findById(id).get();

        System.out.println(user);

    }

 

    /**

     * 查询所有

     */

    @Test

    public void selectAll() {

        List userList = userRepository.findAll();

        System.out.println(userList);

    }

 

    /**

     * 根据Id倒序查询

     */

    @Test

    public void selectAllOrder() {

        Sort sort = new Sort(Sort.Direction.DESC, "id");

        List userList = userRepository.findAll(sort);

        System.out.println(userList);

    }

 

    @Test

    public void pageSelect() {

        int currentPage = 1;

        int pageSize = 2;

        //分页查询

     Pageable page = PageRequest.of(currentPage, pageSize);

     Page pageObject = userRepository.findAll(page);

      //分页 ID倒序

     Sort sort = new Sort(Sort.Direction.DESC, "id");

 Pageable pageOrder = PageRequest.of(currentPage, pageSize, sort);

 Page pageObject2 = userRepository.findAll(pageOrder);

    }

}

 

 

返回目录

上一篇

下一篇

SpringBoot入门 (六) 数据库访问之Mybatis

本文记录学习在SpringBoot中使用Mybatis。

什么是Mybatis

  MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录(官方定义);

官方使用示例代码如下:

1

2

3

4

5

6

7

8

9

10

String resource = "org/mybatis/example/mybatis-config.xml";

InputStream inputStream = Resources.getResourceAsStream(resource);

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

SqlSession session = sqlSessionFactory.openSession();

try {

  BlogMapper mapper = session.getMapper(BlogMapper.class);

  Blog blog = mapper.selectBlog(101);

} finally {

  session.close();

}

通过示例程序可以看到它的执行过程主要有以下几个步骤:

  1 应用程序启动时,根据配置文件生成一个SqlSessionFactory;

  2 通过SqlSessionFactory的到一个SqlSession;

  3 SqlSession内部通过Excutor执行对应的SQl;

  4 返回处理结果;

  5 释放资源;

SpringBoot集成Mybatis

  Mybatis使用有2中方式,一种是使用注解,即在接口定义的方法上通过注解写入要执行的SQL和要完成的数据映射;一种是使用xml配置文件即在xml文件中写相关SQL和完成表与实体的映射。本文我们使用xml文件。

  首先需要引入SpringBoot集成Mybatis的依赖jar包,这里我们只引入了Spring与Mybatis集成的包,springboot默认会自动帮我们引入其他依赖的jar包。

1

2

3

4

5

            org.mybatis.spring.boot

            mybatis-spring-boot-starter

            1.3.2

        

在application.properties文件中配置数据库连接信息和指定mybatis的接口对应的xml

1

2

3

4

5

6

7

#datasoure

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

spring.datasource.url=jdbc:mysql://localhost:3306/test

spring.datasource.username=root

spring.datasource.password=123456

#mybatis

mybatis.mapper-locations=classpath:mybatis/*.xml

如上,我们的mapper xml文件放在reources目录下的mybatis文件夹下

写一个接口,定义我们要完成的功能

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

@Mapper

public interface UserMapper {

 

    /**

     * 根据ID删除

     */

    int deleteByPrimaryKey(Long id);

 

    /**

     * 新增

     */

    int insert(UserInfo record);

 

    /**

     * 根据ID查询

     */

    UserInfo selectByPrimaryKey(Long id);

 

    /**

     * 修改

     */

    int updateByPrimaryKey(UserInfo record);

 

    /**

     * 查询所有

     */

    List selectAll();

}

@Mapper 该注解说名当前类是一个Mybatis的Mapper接口类,交给spring管理,令一种方式是使用注解 @MapperScan(basePackages="...") 说明basePackages及其子包下的接口都交给spring管理,我们多数情况下都会使用@MapperScan这个注解,这样我们就不用在每一个Mapper接口上写注解了。
在xml文件中完成SQl,实现具体的方法,如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

 encoding="UTF-8" ?>

 "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >

 >

   type="org.allen.demo.domain.UserInfo" >

     property="id" jdbcType="BIGINT" />

     property="age" jdbcType="INTEGER" />

     property="name" jdbcType="VARCHAR" />

  

   >

    id, age, name

  

  

  

   parameterType="java.lang.Long" >

    delete from t_user

    where id = #{id,jdbcType=BIGINT}

  

   parameterType="org.allen.demo.domain.UserInfo" useGeneratedKeys="true" keyProperty="id">

    insert into t_user (id, age, name)

    values (#{id,jdbcType=BIGINT}, #{age,jdbcType=INTEGER}, #{name,jdbcType=VARCHAR})

  

   parameterType="org.allen.demo.domain.UserInfo" >

    update t_user

    set age = #{age,jdbcType=INTEGER},

      name = #{name,jdbcType=VARCHAR}

    where id = #{id,jdbcType=BIGINT}

  

 从这个xml文件,我们可以看到以下几点:

1 namespace="org.allen.demo.dao.UserMapper" 通过namespace来指定将当前xml文件的SQL实现的对应的接口Mapper

2 通过 resultMap 完成实体类与数据库表字段的映射

3 xml中的SQL语句都必须写在 th:field="*{name}" th:value="${person.name}"/>

                 th:errors="*{name}" th:style="'color:red'">Name Error

            

            

                age:

                 th:field="*{age}" th:value="${person.age}"/>

                 th:errors="*{age}" th:style="'color:red'">Age Error

            

            

                email:

                 th:field="*{email}" th:value="${person.email}"/>

                 th:errors="*{email}" th:style="'color:red'">Email Error

            

            

                

            

        

    

  th:object 要与后台接收校验得对象保持一致。访问info方法在页面随便输入一些信息,在提交数据,会看到校验结果

 

  如果各项数据都符合规则,则校验通过,跳转至success页面

 

 

返回目录

上一篇

返回第一篇

SpringBoot入门 (十二) 定时任务

本文记录在SpringBoot中使用定时任务。

  在我们的项目中,经常需要用到定时任务去帮我们做一些事情,比如服务状态监控,业务数据状态的更改等,SpringBoot中实现定时任务有2中方案,一种是自带的,我们只需要加上注解即可;另一种是集成Quartz来实现定时任务。

一 SpringBoot 提供的定时任务

  在SpringBoot的starter包中已经提供了对定时任务的支持,我们很容易实现定时任务。修改pom.xml文件,加入如下内容,引入依赖:

   org.springframework.boot

    spring-boot-starter

  在启动类上加注@EnableScheduling 注解,开启定时任务

@SpringBootApplication

@EnableScheduling

public class TimingTaskApplication {

 

    public static void main(String[] args) {

        SpringApplication.run(TimingTaskApplication.class, args);

    }

 

}

  创建定时任务类及要定时执行的方法

1

2

3

4

5

6

7

8

9

10

11

12

@Component

public class ScheduleTaskDemo {

 

    private int num1 = 0;

    private DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

 

    @Scheduled(cron = "*/5 * * * * ?")

    public void test1(){

        System.out.println("这是test1方法第"+ (++num1) + "次执行,执行时间:"+df.format(new Date()));

    }

 

}

  @Component 注解 将当前类交给Spring容器管理

  @Scheduled 注解标明方法是一个定时执行的方法

  启动项目后可以看到控制台打印出的信息

 

  @Scheduled 注解有几个参数可以使用,每个参数的意义不一样,参数及执行规则说明如下:

  fixedRate @Scheduled(fixedRate = 5000) 上一次开始执行时间点之后每5秒执行一次;

  fixedDelay @Scheduled(fixedDelay = 5) 上一次执行完毕时间点之后每5秒执行一次;

  initialDelay @Scheduled(initialDelay = 1, fixedDelay = 6) 第一次延迟1秒后执行,之后按照fixedRate的规则执行;

  cron @Scheduled(cron = "*/5 * * * * ?") 一个表达式,一共有7位,一般只需要设置6为就可以了

  第一位:秒,取值范围是0-59;

  第二位:分,取值范围是0-59;

  第三位:时,取值范围0-23

  第四位:日,取值范围1-31

  第五位:月,取值范围1-12

  第六位:星期,取值范围1-71代表星期日,2代表星期一,7代表星期六;

  第七位:年,取值范围1970-099,可以不设置。

  cron表达式也可以在http://cron.qqe2.com进行在线生成。

 二 SpringBoot集成Quartz

     Quartz是用Java编写的一个开源的任务调度框架。提供了丰富的Api供调用,支持集群环境和持久化,支持多种配置,与SpringBoot可以无缝集成。

  Quartz几个关键元素:

  Job  代表要执行的任务,是个接口,提供了一个方法 execute(JobExecutionContext context);

  JobDetail  代表具体的要执行的任务;

  Trigger  代表调度任务的触发器,配置调度任务的执行规则;

  Scheduler  代表调度容器,一个调度容器中可以注册多个JobDetail和Trigger。

  元素关系如下图:

 

  SpringBoot对Quartz已经提供了支持,我们可以很容易的使用,在pom.xml文件中引入依赖

1

2

3

4

            org.springframework.boot

            spring-boot-starter-quartz

        

  在启动类上加注解 @EnableScheduling ,开启定时执行。

  创建一个要执行的任务继承QuartzJobBean,输出任务执行时间

1

2

3

4

5

6

7

8

9

10

public class MyTask1 extends QuartzJobBean {

 

    private DateFormat df = new SimpleDateFormat("yy-MM-dd HH:mm:ss");

 

    @Override

    protected void executeInternal(JobExecutionContext jobExecutionContext) throws JobExecutionException {

        System.out.println("MyTask1 执行时间:" + df.format(new Date()));

    }

 

}

  创建一个配置类,初始化MyTask1任务所需要的JobDetail和Trigger

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

@SpringBootConfiguration

public class QuartzConfig {

 

    @Bean

    public JobDetail myTask1JobDetail(){

        return JobBuilder.newJob(MyTask1.class).withIdentity("myTask1").storeDurably().build();

    }

 

    @Bean

    public Trigger myTask1Trigger(){

        SimpleScheduleBuilder scheduleBuilder = SimpleScheduleBuilder.simpleSchedule()

                //5秒执行一次

                .withIntervalInSeconds(5)

                .repeatForever();

        SimpleTrigger trigger = TriggerBuilder.newTrigger()

                //指定触发器对应的JobDetail

                .forJob(myTask1JobDetail())

                .withIdentity("myTask1")

                .withSchedule(scheduleBuilder).build();

        return trigger;

    }

 

}

  启动项目,可以看到控制台输出的内容

 

    在上边的方法,我们使用的定时执行方法是在代码中写的固定值,这种局限性比较大,难以满足一些复杂的定制任务执行时间。我们使用Cron表达式来完成定时任务执行时间配置。

  创建任务类,继承QuartzJobBean

1

2

3

4

5

6

7

8

9

10

public class MyTask2 extends QuartzJobBean {

 

    private DateFormat df = new SimpleDateFormat("yy-MM-dd HH:mm:ss");

 

    @Override

    protected void executeInternal(JobExecutionContext jobExecutionContext) throws JobExecutionException {

        System.out.println("MyTask2 执行时间:" + df.format(new Date()));

    }

 

}

  在配置类QuartzConfig中创建任务所需的JobDetail和Trigger

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

@Bean

    public JobDetail myTask2JobDetail(){

        return JobBuilder.newJob(MyTask2.class).withIdentity("myTask2").storeDurably().build();

    }

 

    @Bean

    public Trigger myTask2Trigger(){

        //cron 表达式

        String cronStr = "*/10 * * * * ?";

        //根据表达式设置ScheduleBuilder

        CronScheduleBuilder cronScheduleBuilder = CronScheduleBuilder.cronSchedule(cronStr);

        CronTrigger trigger = TriggerBuilder.newTrigger()

                //指定JobDetail

                .forJob(myTask2JobDetail())

                .withIdentity("myTask2")

                //指定ScheduleBuilder

                .withSchedule(cronScheduleBuilder)

                .build();

        return trigger;

    }

  重启项目,看到控制台输出内容,任务1每5秒执行一次,任务2每10秒执行一次

 

 

 

 

 

返回目录

 备注:此文档借鉴其他博客的,如有问题请及时联系,谢谢

转载于:https://www.cnblogs.com/Aaron-007/p/10382883.html

你可能感兴趣的:(数据库,开发工具,人工智能)