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

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

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

黃艷秀

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

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

黃艷秀

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

基于在項目開發中減少代碼對數據庫語言依賴性的目的,采用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,開發人員通過這些本地API對數據庫進行操作。接口層一接收到外來調用請求就會調用數據處理層來完成具體的數據處理。

1.2 數據處理層:有具體的JDBC代碼,是接口層接口的具體化代碼,包括具體的SQL查找、解析、執行和執行結果反應處理等功能。它主要的目的是根據調用的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 命令運行

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

3 應用結果

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

圖2

4 總結

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

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

[2]夏汛,陳玲.基于Spring MVC和Mybatis的動態表單設計[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
主站蜘蛛池模板: www精品久久| 亚洲小视频网站| 亚洲va在线∨a天堂va欧美va| 国产乱子伦视频在线播放| 在线国产资源| 成人亚洲天堂| 久草热视频在线| 视频二区国产精品职场同事| 乱人伦中文视频在线观看免费| 国产波多野结衣中文在线播放| 成人日韩精品| 欧美日韩国产在线人| 国产成人精品高清不卡在线| 99在线视频免费观看| 中文字幕久久亚洲一区| 无码专区国产精品一区| 婷五月综合| 国产精品自在自线免费观看| 精品日韩亚洲欧美高清a| 国产福利拍拍拍| 日韩国产精品无码一区二区三区 | 日韩黄色精品| 伊人久久婷婷五月综合97色| 亚洲精选高清无码| 国产精品成人免费视频99| 狠狠亚洲五月天| 丁香婷婷综合激情| 日本人妻一区二区三区不卡影院| 亚洲香蕉久久| 国产丰满成熟女性性满足视频| 国产人在线成免费视频| 国产在线观看91精品亚瑟| 日韩国产黄色网站| 99草精品视频| 精品撒尿视频一区二区三区| 久精品色妇丰满人妻| 国产精品女在线观看| 在线播放国产99re| 丁香婷婷激情网| 久99久热只有精品国产15| 成人国产三级在线播放| 五月婷婷精品| 视频在线观看一区二区| 久久久国产精品免费视频| 最新午夜男女福利片视频| 日本免费一区视频| 日韩免费毛片视频| 亚洲精品国产乱码不卡| 国产欧美日韩va另类在线播放| 亚洲乱强伦| 国产69精品久久| 欧美成人午夜影院| 亚洲一区二区无码视频| 欧美人在线一区二区三区| 久青草网站| 午夜一级做a爰片久久毛片| 欧美成人二区| 亚洲男人天堂2020| 亚洲成人精品久久| 免费可以看的无遮挡av无码 | 欧美国产中文| 性色在线视频精品| 色综合久久88色综合天天提莫| 日韩一二三区视频精品| 国产素人在线| 亚洲成A人V欧美综合| 激情六月丁香婷婷四房播| 亚洲 欧美 日韩综合一区| 伊人久热这里只有精品视频99| 国产在线啪| 亚洲第一中文字幕| 国产欧美日韩综合在线第一| 亚洲精品无码专区在线观看| 国产午夜不卡| 国模视频一区二区| 欧美在线免费| 国内精品自在自线视频香蕉| 91精品亚洲| 久久青草精品一区二区三区| 亚洲日本中文综合在线| 四虎永久免费地址| 91亚洲免费视频|