欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

MyBatis入門介紹(超簡單)

MyBatis簡介

延吉網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。成都創(chuàng)新互聯(lián)成立于2013年到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)。

MyBatis的前身叫iBatis,本是apache的一個(gè)開源項(xiàng)目, 2010年這個(gè)項(xiàng)目由apache software foundation 遷移到了google code,并且改名為MyBatis。MyBatis是支持普通SQL查詢,存儲過程和高級映射的優(yōu)秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數(shù)的手工設(shè)置以及結(jié)果集的檢索。MyBatis使用簡單的XML或注解用于配置和原始映射,將接口和Java的POJOs(Plan Old Java Objects,普通的Java對象)映射成數(shù)據(jù)庫中的記錄。

首先介紹一下Mybatis是什么?mybatis是Java的持久層框架, JAVA操作數(shù)據(jù)庫是通過jdbc來操作的,而mybatis是對jdbc的封裝。

使用mybatis之后,開發(fā)者只需要關(guān)注sql語句本身,而不必花時(shí)間去注冊驅(qū)動、創(chuàng)建connection、statement、手動設(shè)置參數(shù),結(jié)果集檢索等jdbc繁瑣的代碼。

mybatis基本過程:Mybatis通過xml或注解的方式將要執(zhí)行的各種statement(statement、preparedStatemnt、CallableStatement)配置起來,并通過java對象和statement中的sql進(jìn)行映射生成最終執(zhí)行的sql語句,最后由mybatis框架執(zhí)行sql并將結(jié)果映射成java對象并返回。

下面通過一個(gè)根據(jù)用戶id查詢用戶信息來學(xué)習(xí)mybatis:

先介紹一下mybatis的兩種主要的配置文件:

SqlMapConfig.xml(mybatis全局配置文件,名稱不固定,用來配置運(yùn)行環(huán)境(數(shù)據(jù)源、事務(wù))

類名+mapper.xml 主要用來配置sql語句

一、首先我們需要在mybatis的全局配置文件(SqlMapConfig.xml)中配置jdbc連接池,和加載mapper.xml.

當(dāng)系統(tǒng)啟動時(shí),會加載這個(gè)全局配置文件,然后通過全局配置文件加載到mapper.xml文件。mapper.xml文件中配置了sql語句。

二、編寫SqlSessionFactory。mybatis的核心就是這個(gè)SqlSessionFactory。通過這個(gè)SqlSessionFactory將配置文件以參數(shù)的形式傳入之后,創(chuàng)建了一個(gè)會話。

然后通過sqlsession來操作數(shù)據(jù)庫,進(jìn)行增刪改查。

下面來對第一步和第二步分別做個(gè)細(xì)致的分析。首先貼上代碼:

sqlMapperConfig.xml

<environments default="development">
    <environment id="development">
    <!-- 使用jdbc事務(wù)管理-->
      <transactionManager type="JDBC" />
    <!-- 數(shù)據(jù)庫連接池-->
      <dataSource type="POOLED">
        <property name="driver" value="${jdbc.driver}"/>
        <property name="url" value="${jdbc.url}"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
      </dataSource>
    </environment>
  </environments>
  <mappers>
    <!-- 通過resource引用mapper的映射文件 -->
    <mapper resource="sqlmap/User.xml" />
  </mappers>

通過這個(gè)配置文件可以看出總的配置文件是配置一些主要信息和加載別的配置文件。當(dāng)mybatis和Spring整合之后,environment就會被廢除。同時(shí),這種全局配置文件只會有一個(gè)。而 "表名+mapper.xml"這種配置文件則會有很多。

下面來分析 "表名+mapper.xml"

<!-- namespace命名空間,為了對sql語句進(jìn)行隔離,方便管理 ,mapper開發(fā)dao方式,使用namespace有特殊作用
mapper代理開發(fā)時(shí)將namespace指定為mapper接口的全限定名
 -->
<mapper namespace="test">
<!-- 在mapper.xml文件中配置很多的sql語句,執(zhí)行每個(gè)sql語句時(shí),封裝為MappedStatement對象
mapper.xml以statement為單位管理sql語句
 -->
  <!-- 根據(jù)id查詢用戶信息 -->
  <!-- 
    id:唯一標(biāo)識 一個(gè)statement
    #{}:表示 一個(gè)占位符,如果#{}中傳入簡單類型的參數(shù),#{}中的名稱隨意
    parameterType:輸入 參數(shù)的類型,通過#{}接收parameterType輸入 的參數(shù)
    resultType:輸出結(jié)果 類型,不管返回是多條還是單條,指定單條記錄映射的pojo類型
   -->
  <select id="findUserById" parameterType="int" resultType="cn.itcast.mybatis.po.User">
    SELECT * FROM USER WHERE id= #{id}
  </select>

    從代碼中可以看出這個(gè)配置文件是用來配置sql語句的。但是應(yīng)當(dāng)注意,最上面的namespace的注釋,namespace命名空間,為了對sql語句進(jìn)行隔離,方便管理 ,mapper開發(fā)dao方式,使用namespace有特殊作用,mapper代理開發(fā)時(shí)將namespace指定為mapper接口的全限定名。

在后面的SQLSessionFactory類中就能看出其作用了。

這個(gè)配置文件中的每個(gè)sql語句,其實(shí)都是jdbc中的statement,這樣的話,其實(shí)mybatis內(nèi)部也是在操作statement。

這里的<select>標(biāo)簽里面?zhèn)鲄⒂玫降氖?{},而我們要用模糊查詢的時(shí)候是不能用這個(gè)直接加上%的。

但是有一種方法就是 使用${}接收參數(shù)!如下:

<!-- 根據(jù)用戶名稱查詢用戶信息,可能返回多條
  ${}:表示sql的拼接,通過${}接收參數(shù),將參數(shù)的內(nèi)容不加任何修飾拼接在sql中。
   -->
  <select id="findUserByName" parameterType="java.lang.String" resultType="cn.itcast.mybatis.po.User">
    select * from user where username like '%${value}%'
  </select>

但是上面這種方法是不加任何修飾的拼接在sql中的,也就是不能防止sql注入,所以這種方法也不能應(yīng)用到實(shí)際項(xiàng)目中!

所以,我在百度上搜到了另一種方式來進(jìn)行模糊查詢,不知道有沒有什么bug,但是我測試是可以用的。

<!-- 根據(jù)用戶名模糊查詢查詢出員工的信息 -->
  <select id="search" resultType="Employee">
    SELECT 
      <include refid="allColumns"/>
    FROM employee a where a.name like concat(concat('%',#{name}),'%')
  </select>

下面來看看sqlsessionFactory會話工廠的代碼:

public class MybatisFirst {
  // 會話工廠
  private SqlSessionFactory sqlSessionFactory;
  // 創(chuàng)建工廠
  @Before
  public void init() throws IOException {
    // 配置文件(SqlMapConfig.xml)
    String resource = "SqlMapConfig.xml";
    // 加載配置文件到輸入 流
    InputStream inputStream = Resources.getResourceAsStream(resource);
    // 創(chuàng)建會話工廠
    sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  }
  // 測試根據(jù)id查詢用戶(得到單條記錄)
  @Test
  public void testFindUserById() {
    // 通過sqlSessionFactory創(chuàng)建sqlSession
    SqlSession sqlSession = sqlSessionFactory.openSession();
    // 通過sqlSession操作數(shù)據(jù)庫
    // 第一個(gè)參數(shù):statement的位置,等于namespace+statement的id
    // 第二個(gè)參數(shù):傳入的參數(shù)
    User user = null;
    try {
      user = sqlSession.selectOne("test.findUserById", 2);
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      // 關(guān)閉sqlSession
      sqlSession.close();
    }
    System.out.println(user);
  }

會話工廠的代碼很簡單,就是:家在配置文件、創(chuàng)建會話工廠、通過會話操作數(shù)據(jù)庫、關(guān)閉會話:

但是請注意第35行的參數(shù)。就是我們前面提到的namespace的test,是為了隔離sql而寫的,這里體現(xiàn)的它的作用!

還有就是selectOne這兩個(gè)參數(shù)各自的意義:第一個(gè)參數(shù)就是我們所說的“表名+mappe.xml”中定義的sql語句,其實(shí)就是一個(gè)statement.第二個(gè)參數(shù)就是sql語句需要傳入的參數(shù),也就是id

總結(jié)

以上所述是小編給大家介紹的MyBatis入門介紹,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!

文章題目:MyBatis入門介紹(超簡單)
標(biāo)題鏈接:http://chinadenli.net/article12/ppiidc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、企業(yè)建站、品牌網(wǎng)站制作、網(wǎng)站制作、全網(wǎng)營銷推廣商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)