龙空技术网

SpringBoot-13-使用JdbcTemplate链接Mysql数据库

springboot葵花宝典 98

前言:

眼前看官们对“jdbctemplatemysql”可能比较关怀,同学们都想要分析一些“jdbctemplatemysql”的相关内容。那么小编同时在网摘上搜集了一些对于“jdbctemplatemysql””的相关资讯,希望兄弟们能喜欢,朋友们一起来了解一下吧!

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: 8899spring:  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表,实体对象如下

@Datapublic 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@Servicepublic 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官方网址。

代码测试可以通过方法的方式进行测试。 如果您觉得本文不错,欢迎关注我支持,您的关注是我坚持的动力!

原创不易,转载请注明出处,感谢支持!如果本文对您有用,欢迎转发分享!

标签: #jdbctemplatemysql