资讯专栏INFORMATION COLUMN

jdbc.postgresql源码分析

SKYZACK / 2301人阅读

摘要:还没接触源码的时候,对的执行过程一头雾水,不知道他是如何执行操作的。它在注册之前先检查是否已经注册,存在的话抛出异常。反之,使用类将驱动注册。文件内容是实现类的包名到类名。源码具体分析,在接下来的学习中将持续更新。

还没接触源码的时候,对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类进行加载,加载后的类进行打印得到每一个实现类。

源码具体分析,在接下来的学习中将持续更新。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/71149.html

相关文章

  • Centos7环境下源码部署ThingsBoard

    摘要:本文为有二次开发需求的同学准备,可以修改源码后编译运行。具体操作即可在端口启动前端服务。 本文为有thingsboard二次开发需求的同学准备,可以修改源码后编译运行。 准备工作 一台4Gb内存以上的服务器(官方推荐8Gb以上,但实测以下配置即可正常运行) showImg(https://segmentfault.com/img/bVbu3eN?w=328&h=86); Centos7...

    Kahn 评论0 收藏0
  • Centos7环境下源码部署ThingsBoard

    摘要:本文为有二次开发需求的同学准备,可以修改源码后编译运行。具体操作即可在端口启动前端服务。 本文为有thingsboard二次开发需求的同学准备,可以修改源码后编译运行。 准备工作 一台4Gb内存以上的服务器(官方推荐8Gb以上,但实测以下配置即可正常运行) showImg(https://segmentfault.com/img/bVbu3eN?w=328&h=86); Centos7...

    justCoding 评论0 收藏0
  • JIRA连接PostgreSQL数据库的详细步骤

    摘要:本文主要介绍如何连接到数据库。创建并配置数据库创建与连接的数据库用户登录角色例如。或通过命令行确保该用户拥有连接数据库以及创建和编辑表的权限。测试连接并保存。注意元素必须指定数据库类型。文件示例启动现在连接到数据库就配置好了。 本文主要介绍如何连接JIRA到PostgreSQL数据库。 首先 检查是否支持你的PostgreSQL版本。请参见支持的平台。 如果是转移JIRA到另一台服务...

    ziwenxie 评论0 收藏0

发表评论

0条评论

SKYZACK

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<