还没接触源码的时候,对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源码分析相关推荐

  1. PostgreSQL源码分析

    PostgreSQL源码结构 PostgreSQL的使用形态 PostgreSQL采用C/S(客户机/服务器)模式结构.应用层通过INET或者Unix Socket利用既定的协议与数据库服务器进行通信 ...

  2. postgreSQL源码分析——索引的建立与使用——GIST索引(2)

    2021SC@SDUSC 本篇博客主要讲解GiST索引创建以及删除的相关函数 这里写目录标题 GIST创建 相关数据结构 GISTBuildState GISTInsertStack gistbuil ...

  3. postgreSQL源码分析——索引的建立与使用——Hash索引(3)

    2021SC@SDUSC 上一篇博客讲了关于Hash索引创建与插入的相关函数,这一篇博客讲述关于溢出页的操作函数以及Hash表的扩展相关的函数. 目录 溢出页的分配和回收 _hash_addovflp ...

  4. postgreSQL源码分析——索引的建立与使用——Hash索引(2)

    2021SC@SDUSC 目录 Hash索引创建 hashbuild函数 _hash_init函数 Hash索引的插入 hashinsert函数 _hash_doinsert函数 总结 Hash索引创 ...

  5. postgreSQL源码分析——索引的建立与使用——各种索引类型的管理和操作(2)

    2021SC@SDUSC 目录 上层操作函数 index_open index_beginscan() index_create() indexcmd.c 下层接口函数 IndexScanDescDa ...

  6. postgreSQL源码分析——索引的建立与使用——Hash索引(1)

    2021SC@SDUSC 目录 Hash索引 Hash索引原理 Hash表 Hash索引结构 Hash的页面结构 元页 桶页,溢出页,位图页 和B-Tree相比的优缺点 优点 缺点 总结 Hash索引 ...

  7. postgreSQL源码分析——索引的建立与使用——B-Tree索引(3)

    2021SC@SDUSC 目录 B-Tree的插入 bt_insert _bt_doinsert BTInsertStateData _bt_search函数 _bt_moveright函数 B-Tr ...

  8. postgreSQL源码分析——索引的建立与使用——各种索引类型的管理和操作(1)

    2021SC@SDUSC 目录 概述 管理索引的系统表 记录索引相关的系统表 与索引系统表相关的后端源码 索引的操作函数 上层操作函数 下层接口函数 概述 索引是指按表中某些关键属性或表达式建立元组的 ...

  9. postgreSQL源码分析综述

    2021SC@SDUSC 目录 综合分析 安装过程 主要源码 分工情况 我的任务 分析方式 综合分析 经过小组讨论和分析,大家一致认为postgreSQL的核心部分在于对SQL功能的实现.而postg ...

  10. postgreSQL源码分析——索引的建立与使用——总结篇

    2021SC@SDUSC 在小组中我负责索引的建立与使用的相关部分,在此一共写了16篇相关的分析报告,着重分析各种索引的操作和管理方法,以及分析了PG中四种最重要的索引B-Tree索引,Hash索引, ...

最新文章

  1. Hive 和普通关系数据库的异同
  2. 10.14 ssh:安全地远程登录主机
  3. 郑州军办计算机学校,郑州市国防科技学校2019级新生开启军训模式
  4. 对于AES和RSA算法的结合使用以及MD5加盐注册登录时的密码加密
  5. js 函数实参列表arguments和形参的那点事儿
  6. 基于JAVA+SpringBoot+Vue+Mybatis+MYSQL的宿舍管理系统
  7. java B2B2C 源码多租户电子商城系统-Spring Cloud整合Netflix Archaius介绍
  8. C语言第五次作业--数据类型
  9. 剑指offer——面试题4:替换空格
  10. 计算机应用基础doc,计算机应用基础.doc
  11. 3D Slicer Programmatically Set Slice Offset and Intersections 用代码修改Slicer中的切片偏移和交叉点显示...
  12. 多元函数法曲率和主曲率的几何解释
  13. 搜狗收录之搜狗推送神器
  14. 大数据职业理解_大数据的职业发展规划
  15. 安利一款提醒休息的工具--重度电脑工作者和程序员必备
  16. python橙色_如何自定义橙色Firefox菜单按钮的外观
  17. 微信小程序消息从公众号推送
  18. Toasts官方教程
  19. Gstreamer基础教程12: Streamer流
  20. Very Good!!! - React 入门实例教程

热门文章

  1. c语言读取tdx日线文件,***EXCEL读取通达信股票日线数据***改为读取通达信股票5分钟数据...
  2. python:DataFrame输出为csv(Pandas的to_csv()使用)
  3. python:批量移动指定文件到指定文件夹(模板)
  4. php js获取session,原创:PHP与纯JS交互在当前页面读取SESSION不用AJAX等
  5. matlab 隶属度计算,基于MATLAB实现的云模型计算隶属度
  6. js字符串编码和unicode编码互转
  7. ionic创建应用的三个模版
  8. Android基础知识、四大组件(转)
  9. jquery 插件解决IE6 PNG不透明
  10. 解读IBM存储虚拟化的两大法宝