springboot整合系列,其他待更新,如整合kafka/rocketmq、elasticsearch、 redis .... 喜欢的点个赞
1.引入jar
2.配置mybatis durid连接池 mapper文件
工程结构,注意mapper注解,目前较为常见使用lombok插件开发代码idea注意插件安装
<packaging>jar</packaging>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.19</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.2</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.21</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
<scope>provided</scope>
</dependency>
</dependencies>
2.连接池配置和mapper文件
server.port=9092
#dbconfig
spring.datasource.druid.url=jdbc:mysql://localhost:3306/product?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
spring.datasource.druid.username=root
spring.datasource.druid.password=hadoop
spring.datasource.druid.initial-size=5
spring.datasource.druid.max-active=200
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
#mybatis mapper
mybatis.mapper-locations=classpath:/mapper/*.xml
3.配置注解扫描
@SpringBootApplication
@MapperScan(basePackages="com.unique.dao")
public class ImApplication {
public static void main(String[] args) {
SpringApplication.run(ImApplication.class, args);
}
}
controller service dao 代码
@Data
public class Product {
private int id;
private String productName;
private String productNo;
}
@RestController
@Slf4j
public class ProductController {
@Autowired
private ProductService productService;
@RequestMapping(value = "getProduct")
public Product getProduct(String id) {
log.info("id:{}", id);
return productService.getProduct(id);
}
}
@Service
public class ProductService {
@Autowired
private ProductDao productDao;
public Product getProduct(String id) {
return productDao.getProduct(id);
}
}
@Mapper //扫描的mapper可以不用添加
public interface ProductDao {
Product getProduct(String id);
void addProduct(List<Product> list);
}
mapper文件
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.unique.dao.ProductDao">
<resultMap id="productMap" type="com.unique.bean.Product">
<result property="id" column="id"></result>
<result property="productName" column="productName"/>
<result property="productNo" column="productNo"/>
</resultMap>
<select id="getProduct" resultMap="productMap">
select id ,productName,productNo from product where id=#{id}
</select>
<insert id="addProduct" parameterType="java.util.List">
insert into product(id,productName,productNo) values
<foreach collection="list" item="dto" separator=",">
(#{dto.id},#{dto.productName},#{dto.productNo})
</foreach>
on duplicate key update
productName=values(productName),productNo=values(productNo)
</insert>
</mapper>
表
create table product
(
id int not null comment '商品id'
primary key,
productName varchar(100) null comment '商品名称',
productNo varchar(100) null comment '商品编号',
productPrice varchar(21) null comment '价格'
)
comment '产品表';