[Mysql] 怎么在 Spring Boot 中使用 JDBC 连接 MySQL 看全部

01、初始化 MySQL 数据库
2 S" {+ U* x9 `4 J4 l' ?- U既然要连接 MySQL,那么就需要先在电脑上安装 MySQL 服务(本文暂且跳过),并且创建数据库和表。
CREATE DATABASE springbootdemo;6 E) v) }0 \) |' P6 l$ ]3 _
DROP TABLE IF EXISTS mysql_datasource;7 |9 Y+ v- J. J/ J- a1 O0 j1 _
CREATE TABLE mysql_datasource (4 H( B( Y6 n$ b3 r
  id varchar(64) NOT NULL,: e: F- @$ s- L
  PRIMARY KEY (id)
2 ^! r. S, j4 x# d8 r* \) ENGINE=InnoDB DEFAULT CHARSET=utf8;
阿里云服务器1核2G低至82元/年,阿里云官活动网址:https://dashi.aliyun.com/site/yun/aliyun 可以用20代金券,即102-20=82。
02、使用 Spring Initlallzr 创建 Spring Boot 项目& A" H- B3 h0 w  w( n
创建一个 Spring Boot 项目非常简单,通过 Spring Initlallzr(https://start.spring.io/)就可以了。
勾选 Lombok、Web、MySQL Driver、Actuator、JDBC 等五个依赖。
1)Lombok 是一种 Java 实用工具,可用来帮助开发人员消除 Java 的一些冗余代码,比如说可以通过注解生成 getter/setter。使用之前需要先在 IDE 中安装插件。
2)Web 表明该项目是一个 Web 项目,便于我们直接通过 URL 来实操。
3)MySQL Driver:连接 MySQL 服务器的驱动器。
申请阿里云服务时,可以使用2000元阿里云代金券,阿里云官网领取网址:https://dashi.aliyun.com/site/yun/youhui
4)Actuator 是 Spring Boot 提供的对应用系统的自省和监控的集成功能,可以查看应用配置的详细信息,例如自动化配置信息、创建的 Spring beans 以及一些环境属性等。
5)JDBC:本篇文章我们通过 JDBC 来连接和操作数据库。
选项选择完后,就可以点击【Generate】按钮生成一个初始化的 Spring Boot 项目了。生成的是一个压缩包,导入到 IDE 的时候需要先解压。
03、编辑 application.properties 文件
! n, c4 K4 K% @' t项目导入成功后,等待 Maven 下载依赖,完成后编辑 application.properties 文件,配置 MySQL 数据源信息。
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springbootdemo, b% ?/ B: p/ B0 B  c# t
spring.datasource.username=root
3 j# |' {, E5 f" h/ dspring.datasource.password=123456% ~1 r2 @  g/ M4 Y2 I2 X% p# h
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
0 ?. f  h' b5 O" u3 M/ {6 j, K# `1)spring.datasource. 为固定格式。
2)URL 为 MySQL 的连接地址。
3)username 为数据库的访问用户名。
4)password 为数据库的访问密码。
5)driver-class-name 用来指定数据库的驱动器。也可以不指定,Spring Boot 会根据 URL(有 mysql 关键字) 自动匹配驱动器。
04、编辑 Spring Boot 项目
! s  R1 b3 x6 L) k& h为了便于我们操作,我们对 SpringBootMysqlApplication 类进行编辑,增加以下内容。
@SpringBootApplication
" Z$ T& r" z! H. A@RestController. N9 }, u$ i! M  I
public class SpringBootMysqlApplication {3 Z4 u, y$ y# I! o0 d6 |
    @Autowired) u: P% P4 F4 t$ ^8 X4 K
    private JdbcTemplate jdbcTemplate;
    @RequestMapping("insert")1 {' Q! }- e3 \; T7 G* ^; L) A
    public String insert() {
1 }1 f9 _/ Y) {. X( o! I: ]        String id = UUID.randomUUID().toString();# @) n# p, P  _& g. w  I# P
        String sql = "insert into mysql_datasource (id,name) values ('"+id+"','沉默王二')";* O* n& ]8 U) I
        jdbcTemplate.execute(sql);& n" c& {2 J5 {/ q: d5 n* J, ?
        return "插入完毕";4 ]; N) y( ^2 Y0 ~6 C3 |
    }
}7 J" A# m0 ]) J% ]4 [
1)@SpringBootApplication、@RestController、@RequestMapping 注解在[之前的文章]()中已经介绍过了,这里不再赘述。
2)@Autowired:顾名思义,用于自动装配 Java Bean。
3)JdbcTemplate:Spring 对数据库的操作在 jdbc 上做了深层次的封装,利用 Spring 的注入功能可以把 DataSource 注册到 JdbcTemplate 之中。JdbcTemplate 提供了四个常用的方法。
①、execute() 方法:用于执行任何 SQL 语句。
②、update() 方法:用于执行新增、修改、删除等 SQL 语句。
③、query() 方法:用于执行查询相关 SQL 语句。
④、call() 方法:用于执行存储过程、函数相关 SQL 语句。
本例中我们使用 execute() 方法向 mysql_datasource 表中插入一行数据 {id:uuid, name:'沉默王二'}。
05、运行 Spring Boot 项目( V; k( q. Q& B5 p/ {
接下来,我们直接运行 SpringBootMysqlApplication 类,这样一个 Spring Boot 项目就启动成功了。
这时候,我们可以直接浏览器的 URL 中键入 http://localhost:8080/insert 测试 MySQL 的插入语句是否执行成功。很遗憾,竟然出错了。
该怎么办呢?这需要我们在连接字符串中显式指定时区,修改 spring.datasource.url 为以下内容。
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springbootdemo?serverTimezone=UTC3 M/ g6 [" E/ D3 }: x: a4 Y
重新运行该项目后再次访问,发现数据插入成功了。
为了确保数据是否真的插入成功了,我们通过 Navicat(一款强大的数据库管理和设计工具)来查看一下。
情况不妙,中文乱码了。该怎么办呢?需要我们在连接字符串中显式指定字符集,修改 spring.datasource.url 为以下内容。
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springbootdemo?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC! M0 _+ x% O8 O8 S
重新运行该项目后再次访问,发现中文不再乱码了。
. {* Y) y- z) h' W