springboot学习(个人学习笔记)-3-连接mysql数据库

本文介绍了三种不同的数据库连接方式:原始JDBC、JdbcTemplate以及MyBatis结合Druid连接池的方法。详细展示了如何在Spring Boot项目中配置并实现这些连接方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

声明:写此博客是为了记录个人技术学习的全过程,防止后期时间久了会有遗忘。希望同时也能帮到有需要的朋友

一、原始JDBC连接数据库

1.在pom.xml加入mysql的依赖。

<!-- 连接mysql数据库 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

2.在src/main/resources/application.properties中设置数据源

#数据库地址
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8    
#用户名
spring.datasource.username=root    
#密码
spring.datasource.password=root    
#数据库驱动
spring.datasource.driverClassName=com.mysql.jdbc.Driver    

3.获取DataSouceConnection进行测试

package com.wangzf.testspbt02.controller;

import java.sql.Connection;
import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.wangzf.testspbt02.po.User;

@RestController
public class HelloController {

	@Autowired
	private DataSource dataSource;
	@RequestMapping("/mysql")
	public String doReq6(){
		try {
			Connection connection = dataSource.getConnection();
			System.out.println("HelloController.doReq6()---conn-"+connection);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return "ok";
	}
}

二、使用JdbcTemplate连接数据库

1.在pom.xml加入mysql的依赖。

<!-- 连接mysql数据库 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>

2.在src/main/resources/application.properties中设置数据源

#数据库地址
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8    
#用户名
spring.datasource.username=root    
#密码
spring.datasource.password=root    
#数据库驱动
spring.datasource.driverClassName=com.mysql.jdbc.Driver    

3.获取DataSouceConnection进行测试

package com.wangzf.testspbt02.controller;

import java.sql.Connection;
import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.wangzf.testspbt02.po.User;

@RestController
public class HelloController {
        @Autowired
	private JdbcTemplate jdbcTemplate;
	
	@RequestMapping("/mysqlJDBC")
	public String doReq7(){
		try {
			DataSource dataSource = jdbcTemplate.getDataSource();
			System.out.println("HelloController.doReq5()---conn-"+dataSource);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return "ok";
	}
}
三、使用mybatis+druid连接数据库

1.在pom.xml加入mysql的依赖。

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.1.1</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.0.29</version>
</dependency>

2.在src/main/resources/application.properties中设置数据源

#数据库配置
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=root
#--------------------------  
# 下面为连接池的补充设置,应用到上面所有数据源中  
# 初始化大小,最小,最大  
# 初始化大小,最小,最大
spring.datasource.initialSize=5
spring.datasource.minIdle=5
spring.datasource.maxActive=20
# 配置获取连接等待超时的时间
spring.datasource.maxWait=60000
# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
spring.datasource.timeBetweenEvictionRunsMillis=60000
# 配置一个连接在池中最小生存的时间,单位是毫秒
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.validationQuery=SELECT 1 FROM DUAL
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
# 打开PSCache,并且指定每个连接上PSCache的大小
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
spring.datasource.filters=stat,wall,logback
# 通过connectProperties属性来打开mergeSql功能;慢SQL记录
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

3.获取DataSouceConnection进行测试

package com.wangzf.testspbt02.controller;

import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {
	
	@Autowired
	private DataSource dataSource;
	
	@RequestMapping("/mysqlDruid")
	public String doReq8(){
		
		try {
			Connection connection = dataSource.getConnection();
			System.out.println("HelloController.doReq8()==dataSource:"+dataSource.getClass());
			System.out.println("HelloController.doReq8()==conn:"+connection);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		
		return "WellDown!";
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值