当前位置: 首页 > article >正文

springboot-创建连接池

操作数据库

代码开发步骤:

  1. pom.xml文件配置依赖
  2. properties文件配置连接数据库信息(连接池用的是HikariDataSource)
  3. 数据库连接池开发
    1. @configurationproperties和@value注解从properties文件中取值+@bean+方法开发

service层代码操作数据库

步骤:

1、数据库相关

  1. 安装与配置主从数据库
    1.  安装方法是-克隆虚拟机
  2. 主从数据库同步数据(后续)
    1. 增删改业务-- service--mysql(主) linux部署 
    2. 查询业务  -- service--mysql(从) linux部署

2、代码开发

  1. 配置pom.xml文件-- mysql数据库相关配置+spring boot操作
  2. properties文件增加连接池数据库信息(连接池用的是HikariDataSource)

增加数据库驱动类,增加url,增加数据库用户名/密码,增加连接池,增加连接池最大数,增加连接池最小空闲值

        配置从库数据库,在名称上更改slave

数据库连接池开发

源码类HikariDataSource,使用2个构造方法

public HikariDataSource()构造连接池
public HikariDataSource(HikariConfig configuration)构造连接池配置

代码开发

因为在配置中看到有数据库连接池,现在新建数据路连接池配置datasourceconfig

使用源码类HikariDataSource,使用2个构造方法

原本的数据库链接代码(接口的内容)

现在也可以使用

封装方法

新建主库/从库,包含的信息一致,连接数据库的基本信息,连接池的连接数量

因为是spring boot项目的主库/从库里的数据库信息是在properties文件内配置,

需要在代码中引入,所以需要增加注解

        目前在封装的代码中,要解决的问题就是,定义属性,然后写入参数,因为现在是主库和从库两份方法,如果只定义属性calssname,主库从库都需要使用,所以需要在方法中加入@value注解

为了解决属性一一对应的问题,

需要在参数里增加注解,同事主库和从库代码修改

目前已经写了主库和从库的连接数据库基本信息和连接池的链接数量的设置,并将代码与配置文件一一对应

但只是列出代码,没有增加返回值,无法调用

增加返回值

 

需要先创建连接池

在类上增加@configuration注解,

为什么要加@bean注解?

1,在类上没有➕@configuration注解时,只是一个普通类

2、需要先创建连接池,随着项目启动;所以在类上增加@configuration注解先进行创建,也需要在主库/从库方法上增加@bean,随着项目启动

 

测试

随着数据源启动测试

 

有问题解决

看问题caused by--这个数据源不能解析

 解决:

因为配置文件时hikari,代码中写错了

测试

把config注解去掉代码也可以配置成功,因为有@value注解就可以配置,并且value是全路径,如果value是只有url路径,就会报错,但也可以增加config注解

 


接下来就可以从池子里借链接就可以操作数据库,返回结果即可


http://www.kler.cn/news/305960.html

相关文章:

  • 【第36章】Spring Cloud之Seata分布式事务
  • GNU力量注入Windows:打造高效跨平台开发新纪元
  • linux上用yolov8训练自己的数据集(pycharm远程连接服务器)
  • C#中的Date Time类
  • java构造器
  • Mysql 面试题总结
  • 51. 数组中的逆序对
  • 使用 Spring Boot + Vue + ElementUI 构建简易评分系统
  • 信息安全工程师(3)TCP/IP协议簇
  • 软件测试工程师面试整理-测试生命周期
  • gingivitis
  • CSS3中的@media查询
  • HTML5超酷炫的水果蔬菜在线商城网站源码系列模板1
  • 如何调试本地npm package
  • MySQL之表的约束
  • 基于springboot的校企招聘管理系统的设计与实现
  • HTTPS的加密流程:保护你的数据传输
  • 关于决策树的一些介绍(二)
  • 物联网之Arduino编程语言
  • 【stm32笔记】使用rtt-studio与stm32CubeMx联合创建项目
  • 鸿蒙 ArkUI组件一
  • 三十七、Gin完成登陆功能
  • solidity-20-sendeth
  • MySQL——数据库的高级操作(三)权限管理(2)授予权限
  • 自动驾驶自动泊车场景应用总结
  • RAII 与 std::lock_guard 在 C++ 中的应用:自动化互斥锁管理与线程安全
  • 【6大设计原则】迪米特法则:解密软件设计中的“最少知识原则”
  • 创建一个Java项目在IntelliJ IDEA中
  • 【AI绘画】Midjourney进阶:景别详解
  • 数学建模常用模型---“算法”总结(含特性和应用场景)