jdbc.postgresql源码分析
还没接触源码的时候,对jdbc的执行过程一头雾水,不知道他是如何执行crud操作的。但是,我在使用的时候发现Class.forNmae(Driver).这个代码。这时候我猜想它是使用反射机制。查看源码果然是这样。Driver类通过静态代码块在Driver类被加载进内存的时候执行register()方法,将驱动进行注册。它在注册之前先检查是否已经注册,存在的话抛出异常。反之,使用DriverManager类将驱动注册。
PgConnection使用通过DriverManger.getConnection()方法获得,这其实时调用PGConnection的构造方法进行初始化,然后调用Driver类的connect()方法返回实例。
同理,PgStatement也是在createPgStatemnt方法中对PgStatement实例进行初始化。具体图片不在展示,它们都调用System.getDefaultProperties()方法获取连接参数,设置具体的执行过程。
jdbc中采用javaSPI机制,也就是它们给予java.sql包中的接口执行具体实现,所谓spi机制我的理解就是声明一系列接口,或者说制定好标准,然后由具体类去实现。我猜jdbc的其它数据库驱动应该也是这种模式。在resource的meta-info下有个service文件夹,里面建立接口的文件,名字是包名到接口名称。文件内容是实现类的包名到类名。然后,通过serviceloader类进行加载,加载后的类进行打印得到每一个实现类。
源码具体分析,在接下来的学习中将持续更新。
jdbc.postgresql源码分析相关推荐
- PostgreSQL源码分析
PostgreSQL源码结构 PostgreSQL的使用形态 PostgreSQL采用C/S(客户机/服务器)模式结构.应用层通过INET或者Unix Socket利用既定的协议与数据库服务器进行通信 ...
- postgreSQL源码分析——索引的建立与使用——GIST索引(2)
2021SC@SDUSC 本篇博客主要讲解GiST索引创建以及删除的相关函数 这里写目录标题 GIST创建 相关数据结构 GISTBuildState GISTInsertStack gistbuil ...
- postgreSQL源码分析——索引的建立与使用——Hash索引(3)
2021SC@SDUSC 上一篇博客讲了关于Hash索引创建与插入的相关函数,这一篇博客讲述关于溢出页的操作函数以及Hash表的扩展相关的函数. 目录 溢出页的分配和回收 _hash_addovflp ...
- postgreSQL源码分析——索引的建立与使用——Hash索引(2)
2021SC@SDUSC 目录 Hash索引创建 hashbuild函数 _hash_init函数 Hash索引的插入 hashinsert函数 _hash_doinsert函数 总结 Hash索引创 ...
- postgreSQL源码分析——索引的建立与使用——各种索引类型的管理和操作(2)
2021SC@SDUSC 目录 上层操作函数 index_open index_beginscan() index_create() indexcmd.c 下层接口函数 IndexScanDescDa ...
- postgreSQL源码分析——索引的建立与使用——Hash索引(1)
2021SC@SDUSC 目录 Hash索引 Hash索引原理 Hash表 Hash索引结构 Hash的页面结构 元页 桶页,溢出页,位图页 和B-Tree相比的优缺点 优点 缺点 总结 Hash索引 ...
- postgreSQL源码分析——索引的建立与使用——B-Tree索引(3)
2021SC@SDUSC 目录 B-Tree的插入 bt_insert _bt_doinsert BTInsertStateData _bt_search函数 _bt_moveright函数 B-Tr ...
- postgreSQL源码分析——索引的建立与使用——各种索引类型的管理和操作(1)
2021SC@SDUSC 目录 概述 管理索引的系统表 记录索引相关的系统表 与索引系统表相关的后端源码 索引的操作函数 上层操作函数 下层接口函数 概述 索引是指按表中某些关键属性或表达式建立元组的 ...
- postgreSQL源码分析综述
2021SC@SDUSC 目录 综合分析 安装过程 主要源码 分工情况 我的任务 分析方式 综合分析 经过小组讨论和分析,大家一致认为postgreSQL的核心部分在于对SQL功能的实现.而postg ...
- postgreSQL源码分析——索引的建立与使用——总结篇
2021SC@SDUSC 在小组中我负责索引的建立与使用的相关部分,在此一共写了16篇相关的分析报告,着重分析各种索引的操作和管理方法,以及分析了PG中四种最重要的索引B-Tree索引,Hash索引, ...
最新文章
- Hive 和普通关系数据库的异同
- 10.14 ssh:安全地远程登录主机
- 郑州军办计算机学校,郑州市国防科技学校2019级新生开启军训模式
- 对于AES和RSA算法的结合使用以及MD5加盐注册登录时的密码加密
- js 函数实参列表arguments和形参的那点事儿
- 基于JAVA+SpringBoot+Vue+Mybatis+MYSQL的宿舍管理系统
- java B2B2C 源码多租户电子商城系统-Spring Cloud整合Netflix Archaius介绍
- C语言第五次作业--数据类型
- 剑指offer——面试题4:替换空格
- 计算机应用基础doc,计算机应用基础.doc
- 3D Slicer Programmatically Set Slice Offset and Intersections 用代码修改Slicer中的切片偏移和交叉点显示...
- 多元函数法曲率和主曲率的几何解释
- 搜狗收录之搜狗推送神器
- 大数据职业理解_大数据的职业发展规划
- 安利一款提醒休息的工具--重度电脑工作者和程序员必备
- python橙色_如何自定义橙色Firefox菜单按钮的外观
- 微信小程序消息从公众号推送
- Toasts官方教程
- Gstreamer基础教程12: Streamer流
- Very Good!!! - React 入门实例教程
热门文章
- c语言读取tdx日线文件,***EXCEL读取通达信股票日线数据***改为读取通达信股票5分钟数据...
- python:DataFrame输出为csv(Pandas的to_csv()使用)
- python:批量移动指定文件到指定文件夹(模板)
- php js获取session,原创:PHP与纯JS交互在当前页面读取SESSION不用AJAX等
- matlab 隶属度计算,基于MATLAB实现的云模型计算隶属度
- js字符串编码和unicode编码互转
- ionic创建应用的三个模版
- Android基础知识、四大组件(转)
- jquery 插件解决IE6 PNG不透明
- 解读IBM存储虚拟化的两大法宝