spring與mybatis怎么整合的你知道嗎谈撒?

?????相信大家每天都在使用spring和mybatis,但是你們知道兩個(gè)框架是怎么整合的嗎?

?????回憶下我們?cè)陧?xiàng)目中使用的場(chǎng)景,我們首先會(huì)定義一個(gè)interface接口,接口上會(huì)一個(gè)@Mapper注解贝乎,代表的意思就是持久層。

@Mapper
public interface IptvInfoDAO {
    @Select("select * from ${tableName} where loginaccount = #{userid} limit 1")
    IptvInfo select(@Param("tableName") String tableName, @Param("userid") String userid);
}

?????接下來(lái)我們就會(huì)在service層叽粹,利用@Autowired 注解將Mapper注入,我們就可以對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作了览效。

@Service
public class IptvInfoService {
    @Autowired
    private IptvInfoDAO iptvInfoDAO;

    public IptvInfo getIptvInfo(String userid) {
        return iptvInfoDAO.select(TableUtil.getUserTable(userid), userid);
    }
}

?????大家有沒(méi)有想過(guò)Mapper實(shí)際是一個(gè)接口,接口不可能實(shí)例化成一個(gè)對(duì)象虫几,將其對(duì)象放入IOC容器中锤灿,那為什么可以在Spring 容器中獲取一個(gè)對(duì)象,然后將對(duì)象賦給屬性呢辆脸?

?????帶著這樣的疑問(wèn)繼續(xù)往下看但校,有的小伙伴說(shuō)那肯定是Spring框架幫我們生成了一個(gè)代理對(duì)象,然后將代理對(duì)象放入到了IOC容器啡氢,自然我們就可以@Autowired依賴注入進(jìn)來(lái)状囱。沒(méi)錯(cuò)术裸,確實(shí)是這樣,原理太抽象啦,我們先通過(guò)一個(gè)簡(jiǎn)單的例子帶大家了解下兩個(gè)框架是如何整合的亭枷。

實(shí)戰(zhàn)演練

?????用到的技術(shù)有java自定義注解袭艺、java反射機(jī)制、jdk 的動(dòng)態(tài)代理,有不熟悉的小伙伴利用業(yè)余時(shí)間充下電吧

1)首先定義一個(gè)注解,給注解一個(gè)屬性sqlArr

package hchang.demo.annotate;

import java.lang.annotation.*;

/**
 * @author lhc
 * 1叨粘、注解本質(zhì)是一個(gè)接口
 * 2猾编、注解的方法相當(dāng)于屬性
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface mySelect {
    String [] sqlArr() default "";
}

2)定義一個(gè)interface接口,接口里面聲明一個(gè)方法升敲,方法上使用我們自定義的注解@mySelect

package hchang.demo.annotate;

public interface QryUserInfo {

    @mySelect(sqlArr = "select password from I_IPTVINFO01 where loginAccount = 'kl333'; ")
    String  queryUserinfo();

}

3)利用JDK的動(dòng)態(tài)代理Proxy.newProxyInstance方法生成一個(gè)代理對(duì)象QryUserInfo答倡,當(dāng)代理對(duì)象的方法被調(diào)用時(shí),自動(dòng)執(zhí)行invoke()方法冻晤,將返回值返回到調(diào)用方法苇羡。

?????代理對(duì)象的三個(gè)參數(shù)分別是類(lèi)加載器、class接口數(shù)組鼻弧、InvocationHandler

package hchang.demo.annotate;


import hchang.demo.util.JDBCCon;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * 手動(dòng)編寫(xiě)模擬實(shí)現(xiàn)Spring整合mybatis,與數(shù)據(jù)庫(kù)交互
 * 1设江、自定義注解@mySelect
 * 2、結(jié)合java反射機(jī)制獲取注解屬性值(sql語(yǔ)句)
 * 3攘轩、結(jié)合java jdk動(dòng)態(tài)代理獲取接口的代理對(duì)象執(zhí)行sql語(yǔ)句
 */

public class AnnotateDemo {
    public static void main(String[] args) {
        QryUserInfo qryUserInfo = (QryUserInfo) Proxy.newProxyInstance(QryUserInfo.class.getClassLoader(), new Class[]{QryUserInfo.class}, new InvocationHandler() {
            @Override
            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
                Object ret = null;
                //獲取注解
                mySelect ms = method.getAnnotation(mySelect.class);
                //獲取注解的屬性值叉存,也就是SQL語(yǔ)句
                String[] strings = ms.sqlArr();
                //執(zhí)行SQL
                JDBCCon jdbcCon = new JDBCCon();
                Connection conn =  jdbcCon.getConnection();
                Statement stmt= null;
                ResultSet rs = null;
                try {
                    stmt = conn.createStatement();
                    rs  =stmt.executeQuery(strings[0]);
                    while (rs.next()) {
                        ret = rs.getString("password");
                    }
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
                finally {
                    if(conn !=null){
                        try {
                            conn.close();
                        } catch (SQLException throwables) {
                            throwables.printStackTrace();
                        }
                    }
                }
                //返回值
                return ret;
            }
        });
        System.out.println(qryUserInfo.queryUserinfo());
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市度帮,隨后出現(xiàn)的幾起案子歼捏,更是在濱河造成了極大的恐慌,老刑警劉巖笨篷,帶你破解...
    沈念sama閱讀 211,561評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瞳秽,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡率翅,警方通過(guò)查閱死者的電腦和手機(jī)练俐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)冕臭,“玉大人腺晾,你說(shuō)我怎么就攤上這事」脊螅” “怎么了悯蝉?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,162評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)托慨。 經(jīng)常有香客問(wèn)我鼻由,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,470評(píng)論 1 283
  • 正文 為了忘掉前任嗡靡,我火速辦了婚禮跺撼,結(jié)果婚禮上窟感,老公的妹妹穿的比我還像新娘讨彼。我一直安慰自己,他們只是感情好柿祈,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布哈误。 她就那樣靜靜地躺著,像睡著了一般躏嚎。 火紅的嫁衣襯著肌膚如雪蜜自。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,806評(píng)論 1 290
  • 那天卢佣,我揣著相機(jī)與錄音重荠,去河邊找鬼。 笑死虚茶,一個(gè)胖子當(dāng)著我的面吹牛戈鲁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播嘹叫,決...
    沈念sama閱讀 38,951評(píng)論 3 407
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼婆殿,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了罩扇?” 一聲冷哼從身側(cè)響起婆芦,我...
    開(kāi)封第一講書(shū)人閱讀 37,712評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎喂饥,沒(méi)想到半個(gè)月后消约,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,166評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡员帮,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評(píng)論 2 327
  • 正文 我和宋清朗相戀三年或粮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片集侯。...
    茶點(diǎn)故事閱讀 38,643評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡被啼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出棠枉,到底是詐尸還是另有隱情浓体,我是刑警寧澤,帶...
    沈念sama閱讀 34,306評(píng)論 4 330
  • 正文 年R本政府宣布辈讶,位于F島的核電站命浴,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜生闲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評(píng)論 3 313
  • 文/蒙蒙 一媳溺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧碍讯,春花似錦悬蔽、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,745評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至倍啥,卻和暖如春禾乘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背虽缕。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,983評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工始藕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人氮趋。 一個(gè)月前我還...
    沈念sama閱讀 46,351評(píng)論 2 360
  • 正文 我出身青樓伍派,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親凭峡。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拙已,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容