spring-boot实例

阅读更多

环境 :

IntelliJ IDEA 2016.2(推荐使用)

mysql

jdk 1.7.0_17
maven 3.3.9

(这个是我本地用的版本)

 

环境和工具安装好后,开始创建项目。

第一步:打开 IDEA 新建项目,创建一个新项目


spring-boot实例_第1张图片
 

然后:


spring-boot实例_第2张图片
  点击 “Next” 按钮继续,会出来一个选项卡,如下图:


spring-boot实例_第3张图片
 

选择完成后点击“Next”继续,然后又出来一个面板:


spring-boot实例_第4张图片
 

 选择完成后点击“Next”继续,选择你的存放路径:


spring-boot实例_第5张图片
 选择完成,项目这是正在打开并加载maven配置,等加载完再继续下一步;

 

第二步:

项目打开,删除没用文件夹以及文件:


spring-boot实例_第6张图片
 

 

 

新建一个类HelloController:


spring-boot实例_第7张图片
 

 

 

然后启动项目,在启动类SpringbootDemoApplication中点击右键,选择Run:


spring-boot实例_第8张图片
 

 

 
spring-boot实例_第9张图片
 

 

 

页面访问查看工程:

http://127.0.0.1:8080/hellow/say

 


spring-boot实例_第10张图片
 

第三步,添加配置,连接数据库添加功能:

删除 多余的包:


spring-boot实例_第11张图片
 

 

 

配置文件 推荐使用application.yml文件,先看一下 application.properties 和application.yml文件的差别:


spring-boot实例_第12张图片
 

application.yml 相对简便一点;必须注意application.yml  中,变量和值之间必须有空格,否则变量变灰,配置会报错如图:


spring-boot实例_第13张图片
 

 

 

认识spring-boot就到这里;

下边是我做的一个例子,仅供参考:

 
spring-boot实例_第14张图片
 

pom.xml:

		
			org.springframework.boot
			spring-boot-starter-data-jpa
		

		
			mysql
			mysql-connector-java
		

 

 

 

 

application.yml (总配置文件):

 

spring:
  profiles:
    active: prod
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/demo
    username: root
    password: 123456
  jpa:
    hibernate:
      ddl-auto: update
    show-sql: true

 

 

application-dev.yml (测试环境配置文件) 

server:
  port: 8080
girl:
  cupSize: B
  age: 20

 

application-prod.yml(生产环境配置文件)

server:
  port: 8085
girl:
  cupSize: G
  age: 20

 

 

 

实体类Girl.class:

package com.imooc;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;

/**
 * Created by user on 2017/4/11.
 * 加注解Entity , 就表明 Girl类是和数据库对应的 , Girl类中的字段会生成数据库Girl表中的字段
 */
@Entity
public class Girl {

    @Id
    @GeneratedValue //表示id为自增长
    private Integer id;

    private String cupSize;

    private Integer age;

    //Constructor 构建无参的构造方法,必须要选无参的,否则连接数据库就报错
    public Girl() {
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getCupSize() {
        return cupSize;
    }

    public void setCupSize(String cupSize) {
        this.cupSize = cupSize;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }
}

 

 

 

 

新建GirlController.class:

package com.imooc;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * Created by user on 2017/4/11.
 */
@RestController
public class GirlController {

    @Autowired
    private GirlRepository girlRepository;

    @Autowired
    private GirlService girlService;

    /**
     * 查询列表
     * @return
     */
    @GetMapping(value="/girls")
    public List girlList(){
        return girlRepository.findAll();
    };


    /**
     * 添加
     * @param cupSize
     * @param age
     * @return
     * 访问链接:http://127.0.0.1:8085/girlAdd?cupSize=F&age=19
     */
    @PostMapping(value="/girlAdd")
    public Girl gilrAdd(@RequestParam("cupSize") String cupSize,
                          @RequestParam("age") Integer age){
        Girl girl = new Girl();
        girl.setCupSize(cupSize);
        girl.setAge(age);
        return girlRepository.save(girl);

    };


    /**
     * 根据ID查找
     * @param girlid
     * @return
     */
//    @GetMapping(value="/findGirlById")  传参字段@RequestParam("id")
    @GetMapping(value="/findGirlById/{id}")
    public Girl findGirlById(@PathVariable("id") Integer girlid){
        return girlRepository.findOne(girlid);
    };


    /**
     * 修改
     * @param girlid
     * @param cupSize
     * @param age
     * @return
     * 访问路径:http://127.0.0.1:8085/updateGirlById?id=2&cupSize=F&age=30
     */
    @PutMapping(value="/updateGirlById/{id}")
    public Girl updateGirlById(@PathVariable("id") Integer girlid,
                               @RequestParam("cupSize") String cupSize,
                               @RequestParam("age") Integer age){
        Girl girl = new Girl();
        girl.setId(girlid);
        girl.setCupSize(cupSize);
        girl.setAge(age);
        return girlRepository.save(girl);
    };


    /**
     * 删除
     * @param id
     */
    @DeleteMapping(value="/deleteGirlById/{id}")
    public void deleteGirlById(@PathVariable("id") Integer id){
         girlRepository.delete(id);

    };

    /**
     * 根据年龄查询 查出多个对象
     * @param age
     * @return
     */
    @GetMapping(value="/findByAge/{age}")
    public List findByAge(@PathVariable("age") Integer age){
        return girlRepository.findByAge(age);
    };


    @PostMapping(value="/insertTwo")
    public void insertTwo(){
        girlService.insertTwo();

    };

}

 

 

 

新建GirlProperties.class:

package com.imooc;

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

/**
 * Created by user on 2017/4/10.
 */
@Component  //注入配置时必加注解
@ConfigurationProperties(prefix = "girl") //获取前缀是 girl 的配置
public class GirlProperties {

    private String cupSize;

    private Integer age;

    public String getCupSize() {
        return cupSize;
    }

    public void setCupSize(String cupSize) {
        this.cupSize = cupSize;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }
}

 

 

 

 

新建GirlRepository.class:

package com.imooc;

import org.springframework.data.jpa.repository.JpaRepository;

import java.util.List;

/**
 * Created by user on 2017/4/11.
 */
public interface GirlRepository extends JpaRepository{


    /**
     * 通过年龄查询
     * @return
     */
    public List findByAge(Integer age);
}

 

 

 

 

 

新建GirlService.class:

package com.imooc;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.PostMapping;

/**
 * Created by user on 2017/4/12.
 */
@Service
public class GirlService {

    @Autowired
    private GirlRepository girlRepository;

    @Transactional  //添加一条数据的时候也要加事务 @Transactional,只有查询的时候不加事务。
    public void insertTwo(){
        Girl girlA = new Girl();
        girlA.setCupSize("B");
        girlA.setAge(18);
        girlRepository.save(girlA);

        Girl girlB = new Girl();
        girlB.setCupSize("DDDDD");
        girlB.setAge(20);
        girlRepository.save(girlB);


    };


}

 

 

 

 

 

 

 

 

 

 

  • spring-boot实例_第15张图片
  • 大小: 37.5 KB
  • spring-boot实例_第16张图片
  • 大小: 51 KB
  • spring-boot实例_第17张图片
  • 大小: 41 KB
  • spring-boot实例_第18张图片
  • 大小: 59.6 KB
  • spring-boot实例_第19张图片
  • 大小: 28.9 KB
  • spring-boot实例_第20张图片
  • 大小: 50.7 KB
  • spring-boot实例_第21张图片
  • 大小: 54.8 KB
  • spring-boot实例_第22张图片
  • 大小: 62.6 KB
  • spring-boot实例_第23张图片
  • 大小: 70.3 KB
  • spring-boot实例_第24张图片
  • 大小: 11.2 KB
  • spring-boot实例_第25张图片
  • 大小: 90.7 KB
  • spring-boot实例_第26张图片
  • 大小: 45 KB
  • spring-boot实例_第27张图片
  • 大小: 14.5 KB
  • spring-boot实例_第28张图片
  • 大小: 27.7 KB
  • 查看图片附件

你可能感兴趣的:(spring-boot实例)