SPI機(jī)制 - JDBC DriverManager
在JDBC4.0之前,我們開發(fā)有連接數(shù)據(jù)庫(kù)的時(shí)候,通常會(huì)用Class.forName("com.mysql.jdbc.Driver")這句先加載數(shù)據(jù)庫(kù)相關(guān)的驅(qū)動(dòng),然后再進(jìn)行獲取連接等的操作。而JDBC4.0之后不需要用Class.forName("com.mysql.jdbc.Driver")來加載驅(qū)動(dòng),直接獲取連接就可以了,現(xiàn)在這種方式就是使用了Java的SPI擴(kuò)展機(jī)制來實(shí)現(xiàn)。
JDBC接口定義
首先在java中定義了接口java.sql.Driver,并沒有具體的實(shí)現(xiàn),具體的實(shí)現(xiàn)都是由不同廠商來提供的。
mysql實(shí)現(xiàn)
在mysql的jar包mysql-connector-java-6.0.6.jar中,可以找到META-INF/services目錄,該目錄下會(huì)有一個(gè)名字為java.sql.Driver的文件,文件內(nèi)容是com.mysql.cj.jdbc.Driver,這里面的內(nèi)容就是針對(duì)Java中定義的接口的實(shí)現(xiàn)。
postgresql實(shí)現(xiàn)
同樣在postgresql的jar包postgresql-42.0.0.jar中,也可以找到同樣的配置文件,文件內(nèi)容是org.postgresql.Driver,這是postgresql對(duì)Java的java.sql.Driver的實(shí)現(xiàn)。
使用方法
上面說了,現(xiàn)在使用SPI擴(kuò)展來加載具體的驅(qū)動(dòng),我們?cè)贘ava中寫連接數(shù)據(jù)庫(kù)的代碼的時(shí)候,不需要再使用Class.forName("com.mysql.jdbc.Driver")來加載驅(qū)動(dòng)了,而是直接使用如下代碼: