博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sharding-jdbc源码解析之jdbc规范重写
阅读量:6002 次
发布时间:2019-06-20

本文共 1947 字,大约阅读时间需要 6 分钟。

hot3.png

说在前面

本文转自“天河聊技术”微信公众号

这次主要介绍的是sharding-jdbc的几个核心接口实现

 

ShardingConnection

类图如下

161044_e4EM_3775437.png

161113_tFbV_3775437.png

com.dangdang.ddframe.rdb.sharding.jdbc.unsupported.AbstractUnsupportedOperationConnection不支持操作的数据库连接对象

com.dangdang.ddframe.rdb.sharding.metrics.MetricsContext 度量上下文,实现了计时功能,threadLocal实现线程安全

ShardingConnection的适配器类,模板方法、适配器模式实现,方便后期扩展

161158_IEja_3775437.png

com.dangdang.ddframe.rdb.sharding.jdbc.core.connection.ShardingConnection支持分片的数据源连接对象

161226_M7df_3775437.png

执行上下文对象

161457_Nut1_3775437.png

sql类型,目前支持这三种类型

161651_XEoH_3775437.png

 

ShardingDatasource

类图如下

161746_C1y2_3775437.png

com.dangdang.ddframe.rdb.sharding.jdbc.unsupported.AbstractUnsupportedOperationDataSource不支持的数据源对象

com.dangdang.ddframe.rdb.sharding.jdbc.adapter.AbstractDataSourceAdapter数据源适配器类用来获取数据库连接对象,适配器模式实现,方便后期扩展

com.dangdang.ddframe.rdb.sharding.jdbc.core.datasource.ShardingDataSource支持分片的数据库对象

161840_boo2_3775437.png

 

ShardingStatement

类图如下

161953_NTZ5_3775437.png

com.dangdang.ddframe.rdb.sharding.jdbc.unsupported.AbstractUnsupportedOperationStatement不支持操作的statement,com.dangdang.ddframe.rdb.sharding.jdbc.adapter.AbstractStatementAdapter statement的适配器实现,适配器模式实现

com.dangdang.ddframe.rdb.sharding.jdbc.core.statement.ShardingStatement支持分片的statement

 

ShardingPreparedStatement

类图如下

162048_Pfda_3775437.png

com.dangdang.ddframe.rdb.sharding.jdbc.unsupported.AbstractUnsupportedOperationPreparedStatement不支持操作的预编译statement

com.dangdang.ddframe.rdb.sharding.jdbc.adapter.AbstractPreparedStatementAdapter 预编译statement的适配器类实现

com.dangdang.ddframe.rdb.sharding.jdbc.core.statement.ShardingPreparedStatement支持分片的预编译statement

 

ShardingResultSet

类图如下

162123_TqbI_3775437.png

com.dangdang.ddframe.rdb.sharding.jdbc.unsupported.AbstractUnsupportedUpdateOperationResultSet 不支持操作的结果集对象

com.dangdang.ddframe.rdb.sharding.jdbc.adapter.AbstractResultSetAdapter 结果集适配器实现,适配器模式

com.dangdang.ddframe.rdb.sharding.jdbc.core.resultset.ShardingResultSet 支持分片的结果集

 

说到最后

本文只要介绍了sharding-jdbc的实现原理,以及实现了jdbc规范的几个主要的类,由此可见sharding-jdbc是对jbdc规范的一种实现,和mysql和oracle的数据库驱动实现一样,sharding-jdbc是一种增强的支持分片的数据库驱动, 这几个对象都是适配器模式对原生态的jdbc规范的进一步扩展,都是用继承这种方式实现的适配器模式,还可以利用接口的方式实现适配器模式,以上内容仅供参考。

 

 

转载于:https://my.oschina.net/u/3775437/blog/1647894

你可能感兴趣的文章
Python学习第二天-编写购物车
查看>>
AD域组策略-只显示指定的控制面板选项配置方法
查看>>
BigTable——针对结构型数据的一种分布式存储系统
查看>>
ip通信基础第二周回顾
查看>>
唯美MACD-完全版
查看>>
Canvas中 drawImage绘制图片不显示
查看>>
MyEclipse新建Server项目
查看>>
Magento错误处理
查看>>
茵茵的第一课
查看>>
Linux实战教学笔记53:开源虚拟化KVM(一)搭建部署与概述
查看>>
PAT 1007
查看>>
USACO习题:Friday the Thirteenth
查看>>
C++ VS2012 内存泄露检测
查看>>
zabbix 批量添加聚合图形
查看>>
北京交通大学第六届新生程序设计竞赛题解
查看>>
求解点关于直线的距离、垂足、对称点公式
查看>>
洛谷 P1577 切绳子【二分答案】
查看>>
用 Google Map 的 Geocoder 接口来反向地址解析
查看>>
在中小型公司如何做好测试——论测试计划的重要性
查看>>
BSS段、数据段、代码段、堆与栈
查看>>