SpringBoot-13-使用JdbcTemplate链接Mysql数据库
在企业项目开发者,数据库的使用是必不可少的一部分,常用的数据库有mysql、oracle、sqlserver、redis等,我们接下来的几章会介绍SpringBoot中如何使用数据库,本章就介绍使用JdbcTemplate链接mysql。
主要步骤有以下几步:
创建项目
添加数据库依赖
在application.yml中配置数据库链接
编写代码实现
2.数据驱动和数据源配置
在我们访问数据库的时候,我们需要配置数据库类型驱动和访问数据库的数据源,在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>
3.数据库配置信息
添加过依赖以后我们还需要在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
4.数据库表的创建
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;
5.创建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
中定义的数据库访问
1. @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官方网址。
代码测试可以通过http://localhost:8899/student/方法的方式进行测试。 如果您觉得本文不错,欢迎关注我支持,您的关注是我坚持的动力!
原创不易,转载请注明出处,感谢支持!如果本文对您有用,欢迎转发分享