成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

支持自動生成sql語句的ibatis改造

開發(fā) 后端
使用iBatis開發(fā)項目工作量比較大,因為每個sql語句都必須自己寫。一般的CRUD sql都是sql 92規(guī)范,基本上都通用所有數(shù)據(jù)庫。如果可以通過ibatis改造實現(xiàn)自動生成iql(ibatis sql)可以簡化大量的工作。

什么是iBatis:

使用ibatis 提供的ORM機(jī)制,對業(yè)務(wù)邏輯實現(xiàn)人員而言,面對的是純粹的Java對象, 這一層與通過Hibernate 實現(xiàn)ORM 而言基本一致,而對于具體的數(shù)據(jù)操作,Hibernate 會自動生成SQL 語句,而ibatis 則要求開發(fā)者編寫具體的SQL 語句。相對Hibernate等 “全自動”O(jiān)RM機(jī)制而言,ibatis 以SQL開發(fā)的工作量和數(shù)據(jù)庫移植性上的讓步,為系統(tǒng) 設(shè)計提供了更大的自由空間。作為“全自動”O(jiān)RM 實現(xiàn)的一種有益補(bǔ)充,ibatis 的出現(xiàn)顯 得別具意義。

使用iBatis開發(fā)項目工作量比較大,因為每個sql語句都必須自己寫。一般的CRUD sql都是sql 92規(guī)范,基本上都通用所有數(shù)據(jù)庫。我想如果可以通過hack ibatis源代碼實現(xiàn)自動生成iql(ibatis sql)可以簡化多少開發(fā)量啊。(最開始有這個想法是因為ibatis for .net實現(xiàn)了這個功能,而ibatis for java沒有)

說干就干,決定依照ibatis for .net的實現(xiàn)方式來實現(xiàn),通過sql-map的parametermap來實現(xiàn)。以最小代碼來實現(xiàn)該功能。

查看了相關(guān)dtd后,發(fā)現(xiàn)《parameter》節(jié)點(diǎn)沒有column定義,《parameterMap》節(jié)點(diǎn)沒有extends定義,《result》和《resultMap》這倒是有。于是修改dtd定義和BasicParameterMapping類,使其支持column。并且修改SqlMapParser類,使其初始化的時候支持column和extends。加入column的目的是為了支持java屬性對應(yīng)到不同的字段上。加入extends的目的是為了重用parametermap。

parameter修改完成后,就要修改dtd文檔定義,使其支持《generate》節(jié)點(diǎn),我們只需要《insert》、《update》、《delete》、《select》這四個節(jié)點(diǎn)支持就行,《statement》和《sql》節(jié)點(diǎn)考慮在下一版支持。generate需要三個屬性,分別是table、where、excludes。其中table表示是對應(yīng)的表,適用于所有;where表示查詢條件字段,適用于select、update、delete;excludes表示要排除哪些parameter,適用于select、update。

dtd文檔定義修改完成后,就可以修改ibatis加載類,使其支持generate。這個切入點(diǎn)比較難找,因為要仔細(xì)分析他的源代碼。經(jīng)過仔細(xì)思考后,發(fā)現(xiàn)ibatis和sql-map支持《include》,決定在include后面加入generate的解析代碼。這樣比較方便的找到了切入點(diǎn)。

找到SqlStatementParser類,找到了parseDynamicTags方法,里面就有include的解析。這里面的判斷代碼是else if,我再加入一個generate的else if 就OK啦。經(jīng)過一天的修改,完成。工作量也不是太大。

【編輯推薦】

  1. ibatis自動生成工具abator使用注意事項
  2. ibatis resultMap groupBy屬性巧使用
  3. 了解iBatis.Net中的ResultMap
  4. ibatis插件的安裝方式
  5. 輕松完成ibatis自動代碼生成
責(zé)任編輯:桑丘 來源: javaeye論壇
相關(guān)推薦

2009-07-16 11:21:19

ibatis主鍵自動生成

2009-07-14 18:24:31

ibatis映射文件

2010-09-07 16:46:56

SQL語句nsert

2009-07-16 09:09:36

ibatis自動代碼

2009-07-21 16:17:28

iBATIS.NET

2009-07-15 17:31:08

iBATIS Ecli

2009-07-16 11:40:23

ibatis自動生成abator

2009-07-14 17:12:26

ibatis自動代碼生

2009-07-21 15:05:43

2010-09-07 16:31:17

SQL語句insert

2009-07-17 14:20:31

ibatis Dao

2021-01-28 15:16:09

程序員技能開發(fā)者

2009-07-24 16:59:57

iBatis模糊查詢

2010-11-18 17:08:44

Oracle使用SQL

2009-06-29 09:08:12

半自動化ORM實現(xiàn)

2009-03-04 13:10:41

SQL語句INSERTDELETE

2009-07-20 16:18:54

iBatis分頁Hibernate式的

2009-07-21 15:21:59

iBATIS.NET多

2023-03-30 09:10:06

SQLSELECTFROM

2010-09-03 15:47:40

SQL語句鎖定
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: av黄色免费 | 亚洲精品在线免费 | 深夜福利影院 | 国产成人精品一区二 | 91精品国产日韩91久久久久久 | 99pao成人国产永久免费视频 | 毛片免费看 | 久久精品免费观看 | 国产精品高潮呻吟久久久久 | 99精品电影 | 天天色天天射天天干 | 久久伊人亚洲 | 久久久久久国产精品 | 久草新视频 | 在线观看中文字幕 | 日本精品久久久久 | 日本电影网站 | 国产精品国产三级国产aⅴ原创 | 在线观看中文字幕 | 免费观看av | 国产日韩电影 | 色综合欧美 | 国产精品久久久久久久久久东京 | 国产精品视频一 | 99精品免费久久久久久久久日本 | 亚洲狠狠爱 | 99视频网站 | 断背山在线观看 | av在线免费观看网站 | 91视频精选| 91久久精品 | 精品久久久久久国产 | 干一干操一操 | 日韩三级在线 | 成人久久久 | 日韩欧美中文字幕在线视频 | 久久亚洲国产精品日日av夜夜 | 久久综合九色综合欧美狠狠 | 国内成人免费视频 | 伊人精品久久久久77777 | 国产女人精品视频 |