回复
SpringBoot-使用JdbcTemplate链接Mysql数据库
qshy
发布于 2022-4-25 22:04
浏览
0收藏
作者 | springboot葵花宝典
来源 | 今日头条
在企业项目开发者,数据库的使用是必不可少的一部分,常用的数据库有mysql、oracle、sqlserver、redis等,我们接下来的几章会介绍SpringBoot中如何使用数据库,本章就介绍使用JdbcTemplate链接mysql。
主要步骤有以下几步:
- 创建项目
- 添加数据库依赖
- 在application.yml中配置数据库链接
- 编写代码实现
数据驱动和数据源配置
在我们访问数据库的时候,我们需要配置数据库类型驱动和访问数据库的数据源,在pom.xml中的配置如下
<!--数据库驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!--JDBC数据源-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
数据库配置信息
添加过依赖以后我们还需要在application.yml中配置数据源信息
server:
port: 8899
spring:
datasource:
username: root
password: root
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/mybatis?useUnicode=true&serverTimezone=Asia/Shanghai&characterEncoding=utf-8&useSSL=false
数据库表的创建
CREATE TABLE `student` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'ID',
`name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '学生姓名',
`sex` enum ('男', '女') DEFAULT '男' COMMENT '性别默认男',
`age` tinyint unsigned default 1 comment '年龄',
`mobile` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '注册手机号',
`email` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '注册邮箱',
`create_date` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0),
`update_date` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0),
`is_enabled` int(2) NULL DEFAULT 1 COMMENT '帐户是否可用(1 可用,0 删除用户)',
PRIMARY KEY (`id`) USING BTREE,
UNIQUE INDEX `name`(`name`) USING BTREE,
UNIQUE INDEX `mobile`(`mobile`) USING BTREE,
UNIQUE INDEX `email`(`email`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 11 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '学生表' ROW_FORMAT = Dynamic;
创建Student的实体对象
根据数据库的表创建Student表,实体对象如下
@Data
public class Student {
private String name;
private String sex;
private int age;
private String email;
private String mobile;
}
编写数据库访问实现
- 定义Sutdent对象的插入、删除和查询的抽象接口
public interface StudentService {
/**
* 获取所有学生信息
* @return
*/
List<Student> getAllSutdents();
/**
* 创建学生
* @param name
* @param age
* @return
*/
int Create(String name,String sex, int age,String mobile, String email);
/**
* 根据name删除学生信息
* @param name
* @return
*/
int deleteByName(String name);
}
- 通过JdbcTemplate实现StudentService中定义的数据库访问
@AllArgsConstructor
@Service
public class StudentServiceImpl implements StudentService {
private JdbcTemplate jdbcTemplate;
@Override
public List<Student> getAllSutdents() {
List<Student> students = jdbcTemplate.query("select name,sex,age,mobile,email from student where is_enabled=1", (resultSet, i) -> {
Student stu = new Student();
stu.setName(resultSet.getString("name"));
stu.setSex(resultSet.getString("sex"));
stu.setAge(resultSet.getInt("age"));
stu.setMobile(resultSet.getString("mobile"));
stu.setEmail(resultSet.getString("email"));
return stu;
});
return students;
}
@Override
public int Create(String name,String sex, int age,String mobile, String email) {
int update = jdbcTemplate.update("INSERT INTO student(name ,sex,age,mobile,email) VALUES(?,?,?,?,?)",
name, sex, age, mobile, email);
return update;
}
@Override
public int deleteByName(String name) {
return jdbcTemplate.update("update student set is_enabled=0 where name = ?", name);
}
}
编写代码的controller层
创建对StudentService的控制层
@Slf4j
@RestController
@RequestMapping("/student")
public class StudentController {
@Autowired
private StudentService studentService;
@GetMapping("create")
public int Create(String name, String sex, int age, String mobile, String email) {
int create = studentService.Create(name, sex, age, mobile, email);
return create;
}
@GetMapping("getallstudents")
public List<Student> getAllSutdents(){
List<Student> allSutdents = studentService.getAllSutdents();
return allSutdents;
}
@GetMapping("deleteByName")
public int deleteByName(String name) {
return studentService.deleteByName(name);
}
}
以上就是我介绍的JdbcTemplate对数据库的基本操作,如果想查看更多操作可以查看其官方网址JdbcTemplate官方网址。
赞
收藏
回复
相关推荐