隨筆-295  評論-26  文章-1  trackbacks-0

          昨天在論壇看到一篇討論嵌入式數據庫HSQLDB(http://www.javaeye.com/topic/79802)的帖子,想到自己曾經讀過部分它的源碼,有一種對某些技術豁然開朗的感覺。所以,也希望和朋友們一起分享,大家有什么好的感受,不如也分享一下吧。下面是我對那個帖子的冗余回復,我覺得有必要專門發一篇帖子重復一下:

          說點題外話,建議大家讀讀HSQLDB的源碼,特別是jdbc driver(org/hsqldb/jdbc包)那部分,寫得清晰易懂。讀了它的部分源碼,我自認為對下面一些問題理解深入了:
          1、JDBC規范和JDBC實現的關系:怎么自己去設計一個規范,一種架構?我是否自己可以為某種數據設計jdbc driver,如何設計?想想php里面各數據庫的函數庫各自為政對程序移植性的影響,就知道jdbc規范有多么重要了。

          2、JDBC協議:JDBC是基于socket之上的,數據包格式(org.hsqldb.Result)(mysql數據包格式公開了)?那么JMS數據包呢?其實,這也可以延伸到分布式協議的設計原理,如RMI、SOAP。其實,這些數據包格式和JSON、YAML這些message格式沒有本質的區別,只不過應用范圍不一樣。任何分布式協議,肯定有一種message格式。

          3、JDBC over HTTP:這樣我們對RMI over IIOP, soap over HTTP, http tunnel原理有更深入的理解。

          4、什么是long connection(jdbc的socket),什么是short connection(http),具體怎么實現?
          3和4這些在HSQLDB的org.hsqldb.HTTPClientConnection類里有實現。

          5、Java客戶端和服務器端的通訊實現:jdbc driver就可以認為是一個java客戶端類庫。那么JMS client呢?還有,像mysql有各種語言的driver,原理是什么。

          6、sql這種command、描述型語言究竟在數據庫里面是個什么地位:sql是怎么傳入jdbc driver,最終和database交互的?我們是否可以設計出另外一種command,形成一種行業標準,它在服務器和客戶端怎么實現的。

          以上我的表達可能有些晦澀,我只想表達一點:大家有興趣就多讀讀經典的源碼,擴展一下自己的設計思路。可能很多人象我一樣,總有忙不完的項目,那么抽幾個小時就夠了,不必深入。
          有很多技術我們理解總是很模糊,當你深入到內部,忽然發現原來就這么回事。我們總覺得IoC很神秘,其實最簡單的IoC容器,也許一個HashMap就夠了。


          引用的http://www.javaeye.com/topic/80532



          大盤預測 國富論
          posted on 2007-09-06 10:21 華夢行 閱讀(669) 評論(0)  編輯  收藏 所屬分類: Oracle
          主站蜘蛛池模板: 苍南县| 翁源县| 大竹县| 临猗县| 鱼台县| 绥江县| 华蓥市| 东至县| 兴海县| 上杭县| 楚雄市| 长治县| 准格尔旗| 黔江区| 两当县| 台北市| 肃宁县| 津南区| 新民市| 土默特左旗| 翁牛特旗| 宁都县| 建宁县| 海兴县| 游戏| 西乡县| 凤冈县| 来安县| 合作市| 陆丰市| 鸡东县| 三原县| 绍兴县| 德钦县| 讷河市| 万年县| 凤翔县| 二连浩特市| 澄城县| 禄劝| 安徽省|