JDBC . 慢读与空想笔记

江湖传言,JDBC建立连接常用两种方法,一为DriverManager,即驱动管理员,一为DataSource数据源。数据源先放一遍,单说说驱动管理员,他会依照特定的数据库URL连接应用程序与数据库。单看这个名字,也不像真正干活的。书上说,驱动管理员会在首次尝试建立连接时,自动加载在类路径中找的着的任意JDBC 4.0驱动。不过,这任意二字又如何理解?(it automatically loads any JDBC 4.0 drivers found within the class path.)既然理解不了,那就先忘了吧。我们看另一件事,管理员找驱动不会是来吃瓜的,我们有理由相信,驱动肯定是来干脏活的。

指南中还提到,方法DriverManager.getConnection 建立一个数据库连接,此方法要求一个数据库URL,返回一个Connection对象。也就是说你自己填一张路条给驱动管理员,要一条指定的连接,管理员依路条找来一个驱动,把路条交给驱动,驱动创建一个连接,这个连接最后会落在你手里。看起来挺合理的,只是Connection factory哪去了?

前面多次提到的数据库URL(Uniform Resource Locator),也就是你填的那张路条到底是什么?它是一个字符串,一个使用特定语法描述与建立连接相关信息的字符串。例如:到哪去找数据库?数据库叫啥名?配置了啥属性等?当然各家数据库所用的语法多少都有些差异,可以看作各种方言。

PostgreSQL讲的是哪种方言呢?

pg之URL可用以下几种样式之一:

To connect, you need to get a Connection instance from JDBC. To do this, you use the DriverManager.getConnection() method:

Connection db = DriverManager.getConnection(url, username, password);

为什么pg的手册看起来就这么顺眼呢?言归正传,关于URL除了样式,还有参数。在pg的世界中除了标准连接参数,驱动还支持若干专有参数。这些属性即可在连接URL中指定,也可在DriverManager.getConnection方法的Properties对象参数中指定。下面是个例子:

String url = "jdbc:postgresql://localhost/test";
Properties props = new Properties();
props.setProperty("user","fred");
props.setProperty("password","secret");
props.setProperty("ssl","true");
Connection conn = DriverManager.getConnection(url, props);

String url = "jdbc:postgresql://localhost/test?user=fred&password=secret&ssl=true";
Connection conn = DriverManager.getConnection(url);

发现了吗?getConnection是重载方法。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,784评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,745评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,702评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,229评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,245评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,376评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,798评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,471评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,655评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,485评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,535评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,235评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,793评论 3 304
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,863评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,096评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,654评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,233评论 2 341

推荐阅读更多精彩内容

  • JDBC概述 在Java中,数据库存取技术可分为如下几类:JDBC直接访问数据库、JDO技术、第三方O/R工具,如...
    usopp阅读 3,525评论 3 75
  • 本人的环境为Myeclipse10、MySQL5.7.15 本文包括:简介JDBC编程步骤打通数据库程序详解—Dr...
    廖少少阅读 3,922评论 7 39
  • JDBC简介 SUN公司为了简化、统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC。JDBC...
    奋斗的老王阅读 1,500评论 0 51
  • 一、相关概念 1.什么是JDBC JDBC(Java Data Base Connectivity,java数据库...
    测试_机器猫阅读 268评论 0 0
  • 昨儿,一不小心就被风“爱”上了,鼻子向它诉说“相思”,害得鄙人早早昏睡又半夜要起身摸索“阿莫西林”来了断它的思。 ...
    木徒阅读 179评论 0 0