SpringBoot学习——No.2

前言:上一节我们说了如何创建、配置、启动springboot项目,本节我们就谈谈如何编写springboot代码。

一、属性配置

在spring中,我们经常要配置很多东西,在springboot中我们也需要配置一些东西,首先我们先配置如何连接上一个数据库,这里我们使用mysql作为数据库。
这里写图片描述
在resources目录下创建一个application.yml,内容如下图
这里写图片描述

上图中的spring:profiles:active:dev是切换不同配置环境使用的,在开发中,我们不免会有不同的开发环境,如测试环境、生产环境、开发环境。
在本节中,我们做了两个环境,一个开发环境,一个生产环境。
这里写图片描述
通过给文件加一个后缀,实现不同的配置环境,在主配置文件中,使用active属性进行程序配置环境的切换。

当我们在配置文件中配置一些固定的值,我们可以再java代码中使用注解获取到
如:

girl:
  age: 18
  cupSize: B
@Value("${age}")
private Integer age;

也可以使用ConfigurationProperties注解获取,然后构成一个对象

@Component
@ConfigurationProperties(prefix = "girl")
public class GirlProperties {    
      private Integer age;    
      private String cupSize;    
      public Integer getAge() {
        return age;
    }    public void setAge(Integer age) {
        this.age = age;
    }    public String getCupSize() {
        return cupSize;
    }    public void setCupSize(String cupSize) {
        this.cupSize = cupSize;
    }
}

二:操作数据库

在springboot中,我们使用jpa的方式操作数据库,jpa中有非常好用的api,十分方便我们队数据库的操作。
首先我们需要先添加两个依赖。

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

刷新pom.xml后

我们创建一个实体类,它对应数据库中的一个表

@Entity
public class Girl {
    @Id
    @GeneratedValue
    private Integer id;    
    private String name;    
    private String cupSize;    
    private Integer age;    
    public Girl() {
    }    
    public Integer getId() {
        return id;
    }    
    public void setId(Integer id) {
        this.id = id;
    }    
    public String getName() {
        return name;
    }    
    public void setName(String name) {
        this.name = name;
    }    
    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;
    }    

    @Override
    public String toString() {
        return "Girl{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", cupSize='" + cupSize + '\'' +
                ", age=" + age +
                '}';
    }
}

首先在数据库中新建一个我们配置文件中对应的数据库,然后执行程序,此时会在数据库中自动创建一个表,也即是girl表,注意,第一次创建的时候ddl-auto:一定要是create

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

三、创建Dao接口

springboot会自动将接口注入到容器中,不需要做任何配置,只需要继承“JpaRepository”即可

public interface GirlRepository extends JpaRepository<Girl, Integer>{  
  List<Girl> getGirlByAge(Integer age);
}

创建好dao层的接口后,我们就直接创建controller控制器了,因为程序简单,我们就不在创建service层了。
创建GirlController,写一个获取所有girl的api和添加girl的api ,自己跑一下就可以了:

@RestController
public class GirlController {    

    @Autowired    
    private GirlRep girlRep;    
    /**
     * 查询所有女生列表
     * @return
     */
    @RequestMapping(value = "/girls",method = RequestMethod.GET)
    public List<Girl> getGirlList(){
        return girlRep.findAll();
    }    /**
     * 添加一个女生
     * @param cupSize
     * @param age
     * @return
     */
    @RequestMapping(value = "/girls",method = RequestMethod.POST)
    public Girl addGirl(@RequestParam("cupSize") String cupSize,
                        @RequestParam("age") Integer age){
        Girl girl = new Girl();
        girl.setAge(age);
        girl.setCupSize(cupSize);
        return girlRep.save(girl);
    }   
 } 

如果需要事务的话,在service层加@Transaction注解即可。
@RestController注解其实是@Controller与@ResponseBody的结合。

四、小结

如此,我们就完成了一个很简单的,springboot操作数据库的程序,应该很简单的,其实除了一些配置和注解,跟springmvc没什么太大的区别。
当然一些更深的东西,我也还没学到,哈哈。
over,期待下次的分享。

代码下载

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值