<dependencies>??
<dependency>??????
<groupId>org.springframework.boot</groupId>???
<artifactId>spring-boot-starter-web</artifactId>??
</dependency>???
<dependency>????
<groupId>org.springframework.boot</groupId>??
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>???
<dependency>?????
<groupId>org.mybatis.spring.boot</groupId>????
<artifactId>mybatis-spring-boot-starter</artifactId>??
</dependency>???
<dependency>???????
<groupId>com.alibaba</groupId>???????
<artifactId>druid-spring-boot-starter</artifactId>?
<version>1.1.10</version>???
</dependency>???
<!--mysql-connector-java-->???
<dependency>???????
<groupId>mysql</groupId>???????
<artifactId>mysql-connector-java</artifactId>??
</dependency>???
<!--jdbc-->???
<dependency>???????
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>??
</dependency>???
<!-- 热部署 devtools -->???
<dependency>???????
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>??
<scope>runtime</scope>???????
<optional>true</optional>???
</dependency>???
<dependency>???????
<groupId>org.projectlombok</groupId>?
<artifactId>lombok</artifactId>?
<optional>true</optional>???
</dependency>???
<dependency>????
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>??????
<scope>test</scope>???
</dependency>
</dependencies>
server:?
port: 8001
spring:?
application:???
name: cloud-payment-service?
datasource:??
# 当前数据源操作类型???
type: com.alibaba.druid.pool.DruidDataSource
# mysql 驱动包?
driver-class-name: org.gjt.mm.mysql.Driver ??
url: jdbc:mysql://localhost:3306/springcloud?useUnicode=true&characterEncoding=utf-8&useSSL=false???
username: root???
password: password
mybatis:?
mapper-locations: classpath:mapper/*.xml?
# 所有 Entity 别名类所在包
type-aliases-package: com.atzwx.springcloud.entities
@SpringBootApplication
public class PaymentMain8001 {
public static viod main(String[] args) {
SpringApplication.run(PaymentMain8001.class, args);
}
}
# 模板
CREATE TABLE `payment`? (
? `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT ‘主键‘,
? `serial` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT ‘支付流水号‘,
? PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = ‘支付表‘
ROW_FORMAT = Dynamic;
# 真实
create table `payment` (
`id` bigint(20) not null auto_increment comment‘id‘,
`serial` varchar(200) default ‘‘,
primary key(`id`)
)engine=innodb auto_increment=1 default charset=utf8;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Payment implements {
// 这里是因为在数据库中,id 的类型是 BIGINT
private Long id;
private String serial;
}
Json封装体CommonResult类
@Data
@AllArgsConstructor
@NoArgsConstructor
public class CommonResult<T> {
private Integer codo;
private String message;
private T data;
public CommonResult(Integer code, String message) {
this(code, message, null);
}
}
@Mapper
public interface PaymentDao {
public int create(Payment payment);
public Payment getPaymentById(@Param("id") Long id);
}
mybatis的映射文件PaymentMapper.xml 在
src\main\resources\mapper 包下
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.atzwx.springcloud.dao.PaymentDao">
<resultMap id="BaseResultMap" type="com.atzwx.springcloud.entities.Payment">
<id column="id" property="id" jdbcType="BIGINT" />
<id column="serial" property="serial" jdbcType="VARCHAR" />
</resultMap>
<!-- public int create(Payment payment); -->
<insert id="create" parameterType="Payment" useGeneratedKeys="true" KeyProperty="id">
insert into payment(serial) values(#{serial});
</insert>
<!-- public Payment getPaymentById(@Param("id") Long id); -->
<select id="getPaymentById" parameterType="Long" resultMap="BaseResultMap">
select * from payment where id=#{id};
</select>
</mapper>
@Service
public interface PaymentService {
public int create(Payment payment);
public Payment getPaymentById(@Param("id") Long id);
}
实现类
@Service
public PaymentServiceImpl implements PaymentService {
@Resource
private PaymentDao paymentDao;
@Override
public int create(Payment payment) {
return paymentDao.create(payment);
}
@Override
public Payment getPaymentById (Long id) {
return paymentDao.getPaymentById(id);
}
}
@RestController
@Slf4j
public class PaymentController {
@Resource
private PaymentService paymentService;
@PostMapping(value = "/payment/create")
public CommonResult<Payment> create(Payment payment) {
int result = paymentService.create(payment);
log.info("****插入结果" + result);
if (result > 0) {
return new CommonResult(200, "插入成功", payment);
}else {
return new CommonResult(100, "插入失败", null);
}
}
@GetMapping(value = "/payment/get/{id}")
public CommonResult<Payment> getPayment(@PathVarialbe("id") Long id) {
Payment payment = paymentService.getPaymentById(id);
log.info("****查询结果" + payment);
if (payment != null) {
return new CommonResult(200, "查询成功", payment);
}else {
return new CommonResult(100, "查询失败,没有对应记录,查询 ID" + id, null);
}
}
}
http://localhost:8001/payment/get/1
结果:
{"code":200,"message":"查询成功","data":{"id":1,"serial":"zwx"}}
1、通过修改 idea 的 workspace.xml 的方式快速打开 Run DashBoard 窗口
2、可能由于 idea 版本不同,需要关闭重启
1、建 module
2、改 pom
3、写 yml
4、主启动
5、业务类
```![](https://img2020.cnblogs.com/blog/1595603/202008/1595603-20200811115836490-1467707594.png)
04_2-Cloud-provider-payment8001 微服务提供者Module模块
原文:https://www.cnblogs.com/zwxo1/p/13474766.html