MyBatis基礎(chǔ)

基本原理

將sql語句寫入到xml文件中,為這個(gè)xml文件提供統(tǒng)一的接口來操作數(shù)據(jù)庫

引入整合

  • 引入兩個(gè)驅(qū)動(dòng)包


    Paste_Image.png
  • 在bean.xml中注冊(cè)sqlSessionFactory(相當(dāng)于jdbc的connection)
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
   <property name="dataSource" ref="dataSource"></property>
   <property name="typeAliasesPackage" value="com.gavin.exam.model"></property>
   <property name="mapperLocations" value="classpath*:com/gavin/exam/model/*Mapper.xml" />  
</bean>

其中typeAliasesPackage 為類型別名包目錄
mapperLocations為sql語句映射xml文件目錄

  • 注冊(cè)sqlSessionTemplate
<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
    <constructor-arg index="0" ref="sqlSessionFactory"></constructor-arg>
</bean>
  • 注冊(cè)dao父類bean和實(shí)現(xiàn)bean
<bean id="baseDao" abstract="true">
    <property name="sqlSessionTemplate" ref="sqlSessionTemplate"></property>
</bean>

<bean id="userDao" class="com.gavin.exam.dao.mybatis.UserDaoImpl" parent="baseDao"/>
  • model包下結(jié)構(gòu)如下
Paste_Image.png
  • 編寫Mapper.xml映射文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.gavin.exam.model.User">
  <!--type 沒有寫全類名的原因是在bean.xml文件下定義了typeAliasesPackage-->
    <resultMap type="User" id="userMap">
        <!--column 為數(shù)據(jù)庫中的類表 property 為model中字段-->
        <id column="id" property="id"/>
        <result column="user_name" property="userName"/>
    </resultMap>
    
    <select id="getUserByName" parameterType="String" resultMap="userMap">
        <![CDATA[
            SELECT * FROM user WHERE user_name = LOWER(#{userName})
        ]]>
    </select>
</mapper>

其中select 中定義增刪改查的語句
屬性resultMap定義了返回map

實(shí)現(xiàn)

  • DAO要extendsSqlSessionDaoSupport
public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao{

    private static final String CLASS_NAME = User.class.getName();
    private static final String SQL_ID_USER_GET_USER_BY_NAME = ".getUserByName";

    @Override
    public User getUserByName(String userName) {
        return getSqlSession().selectOne(CLASS_NAME + SQL_ID_USER_GET_USER_BY_NAME, userName);
    }
}

其中CLASS_NAME對(duì)應(yīng)mapper中的namespace
SQL_ID_USER_GET_USER_BY_NAME對(duì)應(yīng)<select id="getUserByName"中的id

各類節(jié)點(diǎn)

insert

map方法定義

<insert id="createQuestion" useGeneratedKeys="true" keyProperty="id" parameterType="Question" >
    <![CDATA[
        Insert INTO question(display_id, description, created_time, updated_time)
            VALUES(#{displayId}, #{description}, NOW(), NOW())
    ]]>
</insert>

自增長(zhǎng)的id會(huì)自動(dòng)放入傳入的對(duì)象中
DAO中實(shí)現(xiàn)

    @Override
    public void createQuestion(Question question) {
        getSqlSession().insert(QUESTION_CLASS_NAME+SQL_ID_CREATE_QUESTION, question);
    }

此時(shí)book.getId()就能獲得自增長(zhǎng)id

delete

map方法定義

 <delete id="delete" parameterType="int">
      <![CDATA[
             DELETE FROM question WHERE id = #{id}
         ]]>
 </delete>

update

map方法定義

<update id="updateQuestion" parameterType="Question">
    <![CDATA[
        UPDATE question
        SET
            description = #{description},
            updated_time = NOW()
        WHERE
            id = #{id}
    ]]>
</update>

動(dòng)態(tài)sql

動(dòng)態(tài)sql配置語句

  • if
  • where
  • trim
  • set
  • choose(when, otherwise)
  • foreach
  • sql/include

foreach的使用

Paste_Image.png

如圖就會(huì)循環(huán)插入

實(shí)例:根據(jù)某個(gè)狀態(tài)來增加動(dòng)態(tài)增加查詢條件

    <select id="getQuestionCount" resultType="int" parameterType="String">
     <![CDATA[
            SELECT count(*) AS count FROM question WHERE 1=1
        ]]>
        <include refid=""statusSQL""/>
    </select>

動(dòng)態(tài)條件定義

    <sql id=""statusSQL"">
        <if test="status == 'deleted'">
            <![CDATA[
                AND is_deleted = 1
            ]]>
        </if>
        <if test="status == 'undeleted'">
            <![CDATA[
                AND is_deleted = 0
            ]]>
        </if>
    </sql>

其中sql節(jié)點(diǎn)用來定義公用的sql語句
同樣這段代碼可以直接寫進(jìn)getQuestionCount

    <select id="getQuestionCount" resultType="int" parameterType="String">
     <![CDATA[
            SELECT count(*) AS count FROM question WHERE 1=1
        ]]>
                <if test="status == 'deleted'">
            <![CDATA[
                AND is_deleted = 1
            ]]>
        </if>
        <if test="status == 'undeleted'">
            <![CDATA[
                AND is_deleted = 0
            ]]>
        </if>
    </select>

使用總結(jié)

如果是在function中傳兩個(gè)以上的參數(shù)熙掺,那么可以將參數(shù)拼接成一個(gè)map傳到sql節(jié)點(diǎn)中
xml中接收參數(shù)類型為parameterType="map"
其中#會(huì)根據(jù)你參數(shù)的類型做處理
$不會(huì)贮缅,只會(huì)將你的值替換他膳,所以當(dāng)寫入為字符串時(shí)記得加上單引號(hào)逾冬。所以盡量使用# 當(dāng)使用like時(shí)可以使用$

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末旗唁,一起剝皮案震驚了整個(gè)濱河市豆拨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宇色,老刑警劉巖九杂,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異宣蠕,居然都是意外死亡例隆,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門抢蚀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來镀层,“玉大人,你說我怎么就攤上這事皿曲〕辏” “怎么了吴侦?”我有些...
    開封第一講書人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)坞古。 經(jīng)常有香客問我备韧,道長(zhǎng),這世上最難降的妖魔是什么绸贡? 我笑而不...
    開封第一講書人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任盯蝴,我火速辦了婚禮,結(jié)果婚禮上听怕,老公的妹妹穿的比我還像新娘捧挺。我一直安慰自己,他們只是感情好尿瞭,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開白布闽烙。 她就那樣靜靜地躺著,像睡著了一般声搁。 火紅的嫁衣襯著肌膚如雪黑竞。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,541評(píng)論 1 305
  • 那天疏旨,我揣著相機(jī)與錄音很魂,去河邊找鬼。 笑死檐涝,一個(gè)胖子當(dāng)著我的面吹牛遏匆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播谁榜,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼幅聘,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了窃植?” 一聲冷哼從身側(cè)響起帝蒿,我...
    開封第一講書人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎巷怜,沒想到半個(gè)月后葛超,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡延塑,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年巩掺,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片页畦。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖研儒,靈堂內(nèi)的尸體忽然破棺而出豫缨,到底是詐尸還是另有隱情独令,我是刑警寧澤,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布好芭,位于F島的核電站燃箭,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏舍败。R本人自食惡果不足惜招狸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望邻薯。 院中可真熱鬧裙戏,春花似錦、人聲如沸厕诡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽灵嫌。三九已至壹罚,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間寿羞,已是汗流浹背猖凛。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留绪穆,地道東北人辨泳。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像霞幅,于是被迫代替她去往敵國和親漠吻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

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