初始化好工程以后java
新建一个HelloController.javamysql
package com.example.girl1;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class HelloController {
@RequestMapping(value = "/girl",method = RequestMethod.GET)
public String say(){
return "1111111";
}
}
复制代码
在浏览器中输入localhost:8080/girl 内容就是1111111web
resource 目录下 将application.xxx修改为application.ymlspring
server:
port: 8080
servlet:
context-path: /first
复制代码
以后访问就得 :http://localhost:8080/first/girlsql
server:
port: 8080
cupSize: A
复制代码
HelloController.java中shell
@RestController
public class HelloController {
// 经过注解把配置文件中的cupSize注入到变量中
@Value("${cupSize}")
private String cupSize;
@RequestMapping(value = "/girl",method = RequestMethod.GET)
public String say(){
return cupSize;
}
}
复制代码
打开浏览器就能看到cupSize了数据库
package com.example.girl1;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
// 获取前缀是girl的配置
@Component
@ConfigurationProperties(prefix = "girl")
public class GirlProperties {
private String cupSize;
private Integer age;
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;
}
}
复制代码
配置文件json
server:
port: 8080
girl:
cupSize: A
age: 18
复制代码
HelloControllerapi
@RestController
public class HelloController {
@Autowired
private GirlProperties girlProperties;
@RequestMapping(value = "/girl",method = RequestMethod.GET)
public Integer say(){
return girlProperties.getAge();
}
}
复制代码
这样就能作到用前缀来区分,本身打开浏览器看看就明白了浏览器
// application.yml
spring:
profiles:
active: dev
复制代码
server:
port: 8080
girl:
cupSize: B
age: 18
复制代码
server:
port: 8081
girl:
cupSize: A
age: 20
复制代码
java -jar jar包名 --spring.profiles.active=prod
复制代码
// 若是想访问两个
@RequestMapping(value = {"/girl","/hello"},method = RequestMethod.GET)
复制代码
// 能够给类加,访问就得 :localhost:8080/hello/girl了
@RestController
@RequestMapping("/hello")
public class HelloController {
@Autowired
private GirlProperties girlProperties;
@RequestMapping(value = {"/girl"},method = RequestMethod.GET)
public Integer say(){
return girlProperties.getAge();
}
}
// RequestMethod方式有不少
能够使用postman来测试api
复制代码
@RestController
public class HelloController {
@Autowired
private GirlProperties girlProperties;
@RequestMapping(value = {"/girl/{id}"},method = RequestMethod.GET)
public Integer say(@PathVariable("id") Integer myId){
return myId;
}
}
// localhost:8080/girl/100
复制代码
//localhost:8080/girl?id=100
@RestController
public class HelloController {
@Autowired
private GirlProperties girlProperties;
@RequestMapping(value = {"/girl"},method = RequestMethod.GET)
public Integer say(@RequestParam("id") Integer myId){
return myId;
}
}
// 另外一种写法
@RestController
public class HelloController {
@Autowired
private GirlProperties girlProperties;
@RequestMapping(value = {"/girl"},method = RequestMethod.GET)
// 默认值和是否必须传入
public Integer say(@RequestParam(value = "id",required = false,defaultValue = "10") Integer myId){
return myId;
}
}
// RequestMapping 能够写成GetMapping
复制代码
在pom.xml导入包
// jpa和mysql的
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
复制代码
结束后导入一下包
// 运行前先新建一个dbgirl的数据库,utf8mb4
// application.yml
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 // create会把以前的表删掉在新建一个
show-sql: true
复制代码
package com.example.girl1;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
// 这个注解表示这个类就是对应数据库中的表
@Entity
public class Girl {
@Id
@GeneratedValue
private Integer id;
private String cupSize;
private Integer age;
public Girl() {
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
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;
}
}
// 以后表中的那些字段就是girl类中对应过去的
复制代码
get /girls 获取女生列表
post /girls 建立一个女生
get /girls/id 经过id查询一个女生
put /girls/id 经过id更新一个女生
delete /girls/id 经过id删除一个女生
复制代码
新建一个GirlRepository.java的接口
package com.example.girl1;
import org.springframework.data.jpa.repository.JpaRepository;
// Girl类名,Integer是id的类型
public interface GirlRepository extends JpaRepository<Girl,Integer> {
}
复制代码
新建GirlController.java
package com.example.girl1;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
public class GirlController {
@Autowired
private GirlRepository girlRepository;
/* * 查询女生列表 * */
@GetMapping(value = "/girls")
public List<Girl> girlList(){
return girlRepository.findAll();
}
}
// 使用postman测试
复制代码
/* * 新增一个女生 * */
@PostMapping(value = "/girls")
public Girl girlAdd(@RequestParam("cupSize") String cupSize, @RequestParam("age") Integer age){
Girl girl = new Girl();
girl.setCupSize(cupSize);
girl.setAge(age);
return girlRepository.save(girl);
}
复制代码
// 查询一个女生
@GetMapping(value = "/girls/{id}")
public Girl girlFindOne(@PathVariable("id") Integer id){
return girlRepository.findById(id).orElse(null);
}
复制代码
// 更新
@PutMapping(value = "/girls/{id}")
public Girl girlUpdate(@PathVariable("id") Integer id,@RequestParam("cupSize") String cupSize, @RequestParam("age") Integer age){
Girl girl = new Girl();
girl.setId(id);
girl.setCupSize(cupSize);
girl.setAge(age);
return girlRepository.save(girl);
}
复制代码
// 删除
@DeleteMapping(value = "/girls/{id}")
public void girlDelete(@PathVariable("id") Integer id){
girlRepository.deleteById(id);
}
复制代码
// 经过年龄查询女生列表
@GetMapping(value = "/girls/age/{age}")
public List<Girl> girlListByAge(@PathVariable("age") Integer age){
return girlRepository.findByAge(age);
}
复制代码
GirlRepository.java中
package com.first.first;
import org.springframework.data.jpa.repository.JpaRepository;
import java.util.List;
public interface GirlRepository extends JpaRepository<Girl,Integer> {
// 经过年龄查询
public List<Girl> findByAge(Integer age);
}
复制代码
需求是若是我有两条数据,一条插入失败的话另外一条就不能插入,这时候须要加一个事务
GirlService.java
package com.example.girl1;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service
public class GirlService {
@Autowired
private GirlRepository girlRepository;
@Transactional
public void insertTwo(){
Girl girlA= new Girl();
girlA.setAge(10);
girlA.setCupSize("B");
girlRepository.save(girlA);
Girl girlB= new Girl();
girlA.setAge(11);
girlA.setCupSize("F");
girlRepository.save(girlB);
}
}
// 在Girlcontroller里新增
@Autowired
private GirlService girlService;
@PostMapping(value = "/girls/two")
public void girlTwo(){
girlService.insertTwo();
}
复制代码