前言:上一节我们说了如何创建、配置、启动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,期待下次的分享。
代码下载