spring-boot实例

环境 :

IntelliJ IDEA 2016.2(推荐使用)

mysql

jdk 1.7.0_17
maven 3.3.9

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

 

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

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



 

然后:



  点击 “Next” 按钮继续,会出来一个选项卡,如下图:



 

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



 

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



 选择完成,项目这是正在打开并加载maven配置,等加载完再继续下一步;

 

第二步:

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



 

 

 

新建一个类HelloController:



 

 

 

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



 

 

 

 

 

 

页面访问查看工程:

http://127.0.0.1:8080/hellow/say



 

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

删除 多余的包:



 

 

 

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



 

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



 

 

 

认识spring-boot就到这里;

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

 

 

pom.xml:

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-data-jpa</artifactId>
		</dependency>

		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
		</dependency>

 

 

 

 

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<Girl> 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<Girl> 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<Girl,Integer>{


    /**
     * 通过年龄查询
     * @return
     */
    public List<Girl> 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);


    };


}

 

 

 

 

 

 

 

 

 

 

猜你喜欢

转载自fengxiaoshuang429201406254717.iteye.com/blog/2368990