999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

基于mybatis的面向數據庫自動生成技術

2014-07-01 01:13:34黃艷秀
河南科技 2014年4期
關鍵詞:數據庫

黃艷秀

(河南省人才交流中心,河南鄭州 450003)

基于mybatis的面向數據庫自動生成技術

黃艷秀

(河南省人才交流中心,河南鄭州 450003)

基于在項目開發(fā)中減少代碼對數據庫語言依賴性的目的,采用mybatis框架,通過自動生成類、接口和代碼,結合Spring翻轉注入的工廠方法,完成了對程序員的解放,降低了代碼耦合度,增加項目的可移植性。

持久;映射;數據庫連接;接口;耦合度;封裝

在以JAVA語言為基礎的面向對象設計的項目中,肯定需要對數據庫進行連接。而JAVA中對象類都需要在數據庫中有相對應的表,所以就需要去編寫每一個類的每一個屬性的數據庫語句。但是在項目建設過程中會經常對對象類或者數據庫中的表進行修改,那么每一次修改都需要再去修改相對應的數據庫語句,那么每一次工作中,代碼量是十分巨大的。Mybatis在這里向大家提供了一種可以根據數據庫中的表自動生成數據庫和java類的方法,十分便捷。

1 mybatis介紹

Mybatis本來是阿帕奇公司(即apache,tomcat出品公司)研究的一個面向廣大用戶的開源項目“ibatis”。其本意是Internet和abatis兩個單詞的組合,是提供給大家的一個持久層框架[1]。后來apache公司將其轉讓給了谷歌公司,并且更名為mybatis。Mybatis自動生成方式替代了幾乎所有的JDBC代碼和參數設置以及結果搜索。它通過簡單的XML文件對原始映射和屬性進行配置,直接生成接口和JAVA對象的數據庫表或者將數據庫表生成接口和JAVA類。Mybatis主要有三層主要功能框架:

1.1 API接口層:將自動生成的JDBC代碼封裝提供給生成類以外的類或程序使用的接口API,開發(fā)人員通過這些本地API對數據庫進行操作。接口層一接收到外來調用請求就會調用數據處理層來完成具體的數據處理。

1.2 數據處理層:有具體的JDBC代碼,是接口層接口的具體化代碼,包括具體的SQL查找、解析、執(zhí)行和執(zhí)行結果反應處理等功能。它主要的目的是根據調用的API請求轉為具體的代碼,然后由代碼完成一次數據庫操作。

1.3 基礎支撐層:負責最基礎的管理功能,包括數據庫連接和事務管理、數據庫配置加載和緩存處理等內容,這些本應該是最基礎的東西,將他們合成一個最基本的組件,為上層的數據處理層提供服務。

2 項目中mybatis應用方法

2.1 數據庫配置

在底層數據庫要將每一個需要調用的類配置成一個表的形式,并將數據類型和長度按照需要配置,如圖1。

圖1

在表中,一定只能配置一個主健,并且將主鍵的配置完成。如圖中,id即為主鍵,且每一個屬性名的類型都一定要選擇清除,將長度配置完畢。

2.2 XML文件配置

Mybatis基本只需要兩個最主要的XML文件,一個是mybatis-config.xml,一個是generatorConfig.xml,第一個是mybatis的功能配置文件,第二個是mybatis自動生成功能對表和類以及接口的配置文件。但是一般在項目中,mybatis是和Spring框架結合使用的,在Spring框架的applicationContext-database.xml配置文件中,要將mybatis配置進去,,代碼如下:

可以看到,Spring也是講mybatis功能當做一種反轉注入的類工廠(Factory),用以數據(類)的調用。這樣,mybatis就和Spring框架結合在一起了。在mybatis-config.xml中,將自動生成的所有接口的JDBC語言實現代碼所在的文件配置進來,這樣,mybatis工廠就可以自動查詢到每一個接口及其代碼。其方式如下:

下面重點介紹一下generatorConfig.xml文件,在其中,要將數據庫的連接方式、賬號密碼等內容配置好,將自動生成的接口和JDBC語句所在文件夾配置好,還要將底層數據庫的表和相對應的類配對好,寫在一個table標簽中,如下:

其中jdbcConnection標簽是數據配置,table是表和類配置,名字要一一對應。

在下一部分命令運行中,所有的數據庫表自動生成類、接口和數據庫語句都是通過generatorConfig.xml配置好后,才能自動生成的,在以后項目建設的日子里,每當你對類和數據庫進行了修改后,都只需要運行命令,就可自動生成文件,不再需要去人工修改代碼、參數和配置[2]。

2.3 命令運行

在開發(fā)環(huán)境的服務器中,配置一句mybatis-generator: generate,運行,即可在配置文件所寫的文件位置中自動生成需要的類、API接口和代碼。這對于開發(fā)人員來講,是一個解放程序員的進步。

3 應用結果

在上面的命令運行后,就在項目對應位置生成文件如圖2。其中dao.*中的*Mapper.java是所有關于device這個類的API接口,包括增刪改查和計數這些功能,而且每種還根據用戶需要提供了不同種類的接口。在model.*中主要是生成了數據庫中table所對應的java類和類的example,用于類的調用和注入值等功能。Map.*中是dao*中接口的數據庫代碼化[3]。其中把所有提供的接口和基礎連接都已數據庫語言表達出來。

圖2

4 總結

Mybatis技術對DAO層進行了封裝,使得開發(fā)人員不需要在做后臺和頁面開發(fā)的同時還要去關系數據庫的鏈接和調用。在配置文件中將SQL語句自動生成且封裝,避免了項目遷移時對數據庫的依賴性,降低了代碼的耦合度,增加了項目的可移植性。同時,又能讓你了解到底層數據庫的搭建,不至于對數據庫完全不知曉。對J數據庫語言的封裝和API的生成,減少了程序員在開發(fā)過程中使用JDBC的機會,釋放了大量開發(fā)時間,解放了開發(fā)人員。

[1]李澎林,朱國清,吳斌.基于iBatis SQL Map的數據持久層實現[J].應用研究,2008

[2]夏汛,陳玲.基于Spring MVC和Mybatis的動態(tài)表單設計[J].計算機光盤軟件與應用,2012,20.

[3]徐雯,高建華.基于Spring MVC及MyBatis的Web應用框架研究[J].微型電腦應用,2012.7.

TP311

A

1003-5168(2014)04-0021-02

猜你喜歡
數據庫
數據庫
財經(2017年15期)2017-07-03 22:40:49
數據庫
財經(2017年2期)2017-03-10 14:35:35
兩種新的非確定數據庫上的Top-K查詢
數據庫
財經(2016年15期)2016-06-03 07:38:02
數據庫
財經(2016年3期)2016-03-07 07:44:46
數據庫
財經(2016年6期)2016-02-24 07:41:51
數據庫
財經(2015年3期)2015-06-09 17:41:31
數據庫
財經(2014年21期)2014-08-18 01:50:18
數據庫
財經(2014年6期)2014-03-12 08:28:19
數據庫
財經(2013年6期)2013-04-29 17:59:30
主站蜘蛛池模板: 国产成人综合亚洲网址| 黄色网址免费在线| 国产成人禁片在线观看| 中文字幕波多野不卡一区| 国产日本欧美亚洲精品视| YW尤物AV无码国产在线观看| 亚洲二三区| 国产成人乱无码视频| 毛片久久久| 国产对白刺激真实精品91| 日本欧美成人免费| 午夜国产精品视频| 国产爽爽视频| 国产九九精品视频| 欧美yw精品日本国产精品| 免费精品一区二区h| 午夜国产理论| 极品国产一区二区三区| 国产自在线播放| 中文字幕久久波多野结衣 | 亚洲国产91人成在线| 色婷婷啪啪| 亚洲香蕉久久| 午夜欧美在线| 国产迷奸在线看| 中文字幕乱码中文乱码51精品| 2022国产无码在线| 国产女同自拍视频| 亚洲精品人成网线在线 | 72种姿势欧美久久久大黄蕉| 免费无码AV片在线观看国产| 人妻精品久久无码区| 91精品亚洲| 欧美色图久久| www成人国产在线观看网站| 国产成人亚洲精品无码电影| 中文无码毛片又爽又刺激| 国产成人高清亚洲一区久久| 无码专区在线观看| 亚洲欧洲自拍拍偷午夜色| 国产人免费人成免费视频| 日韩欧美国产综合| 国产爽妇精品| 亚洲欧美不卡| 成年女人a毛片免费视频| 色久综合在线| 全色黄大色大片免费久久老太| 好紧好深好大乳无码中文字幕| 国产成人福利在线视老湿机| 亚洲AⅤ永久无码精品毛片| 日日噜噜夜夜狠狠视频| 黄色网站在线观看无码| 欧美va亚洲va香蕉在线| 成人国产一区二区三区| 国产无码网站在线观看| 欧美日在线观看| 熟妇人妻无乱码中文字幕真矢织江| 91福利一区二区三区| 香蕉视频在线观看www| 欧美a级在线| 国产对白刺激真实精品91| 九九视频免费在线观看| 亚洲综合18p| 日本免费福利视频| 亚洲中久无码永久在线观看软件| 美女国内精品自产拍在线播放| 漂亮人妻被中出中文字幕久久| 在线欧美一区| 直接黄91麻豆网站| 在线国产毛片| 国产精品精品视频| 中国特黄美女一级视频| 亚洲有无码中文网| 毛片久久网站小视频| 一区二区三区精品视频在线观看| 韩国自拍偷自拍亚洲精品| 国产91熟女高潮一区二区| 亚洲免费三区| 欧美国产日本高清不卡| 亚洲欧美成人| 国产综合在线观看视频| 国产在线八区|