热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

自定义实现MySQL连接池:从零构建数据库连接池并与SpringData集成

在实际开发中,连接池是最常使用的数据库管理技术之一。连接池通过创建和管理一组预初始化的数据库连接,使得这些连接可以被多个线程复用,从而显著提高应用程序的性能和资源利用率。本文将详细介绍如何从零开始构建一个自定义的MySQL连接池,并将其与SpringData进行集成,以实现高效、可靠的数据库操作。

GitHub : 传送门

实际开发中最常用到连接池,连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。连接池的出现可以减少资源的频繁请求和释放。

连接池实现的核心就是:当用户关闭连接时,我们把连接返回到池中,好使其他线程使用,而并非真正的关闭。

从这个角度分析,我们只需要重写连接的 close 方法,就可以实现一个简单的连接池。可以使用包装设计模式或者是代理模式,重写 close 方法即可。

但是包装设计模式需要重写所有的类,比较麻烦,所以我使用的是代理模式。(具体代码可以参考cn.xiuyu.pool)

GitHub 地址:传送门

Spring Data 是一个用于简化数据库访问,并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷,并支持 map-reduce 框架和云计算数据服务。

当 spring data 与 jpa 子项目一起使用时只需要写一个 dao 接口,继承一个 jparepository 接口。spring data 就会自动帮你生成一个代理 dao 类,并自动生成 sql 语句运行并返回结果,当有复杂操作时在方法上面添加 @Query 注解 就可以自动 sql 语句。这也是我实现的核心。

仿照 spring data 实现了自动生成代理类,支持简单的 CURD,分页,和一些自定的复杂查询

如何使用?

写一个 UserResponse 类,将 UserRespons 继承Repository,再一个实体类 User 用于封装数据,然后在测试类使用ResponseFactory.getInstance()获取 ResponseFactory 的工厂实例,然后再使用工厂方法createResponse创建 dao 代理对象,然后就可以进行快乐的操作了.(这也是我设计不合理的地方,很狗血,这也是我不想继续写下去的原因)

UserResponse 类

public interface UserResponse extends Repository{

@Delete("delete from user where id=?")

public void deletebyid(int id);

@Query("from User where id=?")

public User QuerybyID(int id);

@Updata("update user set name=?,password=? where id=?")

public void updatebyID(String name,String password,int id);

}

封装的方法使用

public class TestOrm {

//获取代理的类和封装的实体类

ResponseFactory factory = ResponseFactory.getInstance();

UserResponse createResponse = factory.createResponse(UserResponse.class, User.class);

@Test

//添加用户

public void add() throws Exception{

for(int i&#61;0;i<100;i&#43;&#43;){

User u &#61; new User(i&#43;"",i&#43;"张三","123123");

createResponse.insert(u);

}

}

&#64;Test

//更新用户

public void update() throws Exception{

User u &#61; new User("1","1","1");

createResponse.update(u);

}

&#64;Test

//删除用户

public void delete() throws Exception{

createResponse.delete(1);

}

&#64;Test

//查询用户

public void query() throws Exception{

User u &#61; createResponse.query(1);

System.out.println(u);

}

&#64;Test

//获取总数

public void count() throws SQLException{

System.out.println(createResponse.Querycount());

}

&#64;Test

//分页

public void page() throws InstantiationException, IllegalAccessException, SQLException{

//从第 0 叶开始查询 查询 3 页

PageEntity queryBypage &#61; createResponse.QueryBypage(new PageEntity(0, 3));

List entity &#61; queryBypage.getEntity();

System.out.println(entity.size());

for(User u:entity){

System.out.println(u);

}

}

&#64;Test

//通过 &#64;Query 注解查询

public void querybysql() {

User querybyID &#61; createResponse.QuerybyID(2);

System.out.println(querybyID);

}

&#64;Test

//通过 &#64;Delete 注解删除

public void deletebysql(){

createResponse.deletebyid(1);

}

&#64;Test

//通过 &#64;Update 注解更新

public void updatebysql(){

createResponse.updatebyID("123", "123", 2);

}

}

我的其他系列文章

自己手写 springmvc&#xff1a;传送门

jvm 虚拟机系列 &#xff1a;传送门

SpringIOC 源码分析系列文章 &#xff1a;传送门

SpringAOP 源码分析细类文章&#xff1a;传送门

当然还有我的小博客 &#xff1a;传送门打一波广告(逃



推荐阅读
  • 利用Java与Tesseract-OCR实现数字识别
    本文深入探讨了如何利用Java语言结合Tesseract-OCR技术来实现图像中的数字识别功能,旨在为开发者提供详细的指导和实践案例。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 在使用 DataGridView 时,如果在当前单元格中输入内容但光标未移开,点击保存按钮后,输入的内容可能无法保存。只有当光标离开单元格后,才能成功保存数据。本文将探讨如何通过调用 DataGridView 的内置方法解决此问题。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 本文详细介绍了Java中org.w3c.dom.Text类的splitText()方法,通过多个代码示例展示了其实际应用。该方法用于将文本节点在指定位置拆分为两个节点,并保持在文档树中。 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 本文介绍如何在 FireDAC 环境下实现 FDMEMTable 字段的自动获取,为开发人员提供便捷的数据处理方式。 ... [详细]
author-avatar
叮咚叮咚_叮
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有