Eclipse利用Maven快速上手搭建MyBatis


一、what is maven?

  Maven項目對象模型(POM),可以通過一小段描述信息來管理項目的構建,報告和文檔的項目管理工具軟件。

  Maven 除了以程序構建能力為特色之外,還提供高級項目管理工具。由於 Maven 的缺省構建規則有較高的可重用性,所以常常用兩三行 Maven 構建腳本就可以構建簡單的項目。由於 Maven 的面向項目的方法,許多 Apache Jakarta 項目發文時使用 Maven,而且公司項目采用 Maven 的比例在持續增長。
  Maven這個單詞來自於意第緒語(猶太語),意為知識的積累,最初在Jakata Turbine項目中用來簡化構建過程。當時有一些項目(有各自Ant build文件),僅有細微的差別,而JAR文件都由 CVS來維護。於是希望有一種標准化的方式構建項目,一個清晰的方式定義項目的組成,一個容易的方式發布項目的信息,以及一種簡單的方式在多個項目中共享JARs。

二、安裝與配置

  2.1、直接下載(需jdk1.7或更高)

地址:直接下載

  2.2、官網下載:http://maven.apache.org/download.cgi

 

   2.3、Maven與Eclipse關聯

 

   2.4、創建Maven項目,並配置pom.xml

     <dependencies>
         <!-- 添加MyBatis框架3.4.6版本 -->
         <dependency>
             <groupId>org.mybatis</groupId>
             <artifactId>mybatis</artifactId>
             <version>3.4.6</version> <!-- 版本號視情況修改 -->
         </dependency>
         <!-- 添加MySql驅動包 -->
         <dependency>
             <groupId>mysql</groupId>
             <artifactId>mysql-connector-java</artifactId>
             <version>5.1.25</version>
         </dependency>
     </dependencies>

  2.5、創建XML配置MyBatis

 

 <?xml version="1.0" encoding="UTF-8"?>
 <!DOCTYPE configuration
   PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
   "http://mybatis.org/dtd/mybatis-3-config.dtd">
 <configuration>
     <environments default="development">
         <environment id="development">
             <transactionManager type="JDBC" />
             <dataSource type="POOLED">
                 <property name="driver" value="com.mysql.jdbc.Driver" /> <!-- 驅動類型 -->
                 <property name="url" value="jdbc:mysql://localhost:3306/sam" /> <!-- 連接字符串 -->
                 <property name="username" value="root" /> <!-- 用戶名 -->
                 <property name="password" value="root" /> <!-- 密碼 -->
             </dataSource>
         </environment>
     </environments>
     <mappers>
         <mapper resource="DeptMapper.xml" /> <!-- 映射SQL語句的XML文件 -->
     </mappers>
 </configuration>

  2.6、創建XML映射SQL語句

 <?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="Dept">
     <!-- 插入單個部門信息 -->
     <insert id="InsertDept">
         INSERT INTO DEPT (DNAME,LOC)
         VALUES (#{DName},#{Loc})
     </insert>
 </mapper>

CRUD語法

 <insert id="insertAuthor">
   insert into Author (id,username,password,email,bio)
   values (#{id},#{username},#{password},#{email},#{bio})
 </insert>
 
 <update id="updateAuthor">
   update Author set
     username = #{username},
     password = #{password},
     email = #{email},
     bio = #{bio}
   where id = #{id}
 </update>
 
 <delete id="deleteAuthor">
   delete from Author where id = #{id}
 </delete>

  2.7、創建實體類

表結構

 package com.chenyanbin;
 
 public class Dept {
     //部門名稱
     private String DName;
     //部門位置
     private String Loc;
     public String getDName() {
         return DName;
     }
     public void setDName(String dName) {
         DName = dName;
     }
     public String getLoc() {
         return Loc;
     }
     public void setLoc(String loc) {
         Loc = loc;
     }
 }

  2.8、創建Main函數

 package com.chenyanbin;
 
 import java.io.IOException;
 import java.io.InputStream;
 import org.apache.ibatis.io.Resources;
 import org.apache.ibatis.session.SqlSession;
 import org.apache.ibatis.session.SqlSessionFactory;
 import org.apache.ibatis.session.SqlSessionFactoryBuilder;
 
 public class TestMain {
     public static void main(String[] args) throws IOException {
         //創建實體類
         Dept dept = new Dept();
         dept.setDName("上海事業部");
         dept.setLoc("上海");
         //加載XML文件
         InputStream is = Resources.getResourceAsStream("myBatis-config.xml"); //加載MyBatis的配置文件
         //初始化SqlSessionFactory
         SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
         SqlSession session = factory.openSession();
         session.insert("InsertDept", dept);
         session.commit();
         session.close();
     }
 }

 

  

  2.9、項目文件目錄圖

 

 以上配置完成,但是博主碰到一個問題,數據庫保存進去了,程序警告,警告如下:

 

 WARNING: An illegal reflective access operation has occurred

WARNING: Illegal reflective access by org.apache.ibatis.reflection.Reflector (file:/C:/Users/Windows10/.m2/repository/org/mybatis/mybatis/3.4.6/mybatis-3.4.6.jar) to method java.lang.Class.checkPackageAccess(java.lang.SecurityManager,java.lang.ClassLoader,boolean)
WARNING: Please consider reporting this to the maintainers of org.apache.ibatis.reflection.Reflector
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release

  網上查了下,jdk8之后對反射做限制了,有兩種解決方案

  1. 把jdk回到jdk9之前
  2. 升級MyBatis

 三、MyBatis框架執行流程解析

  • 將sql語句和數據庫配置信息保存在配置文件
  • 在MyBatis運行時,將配置信息存儲Configuration對象
  • 在創建SqlSession對象,提供屬性
    • Configuration對象
    • dirty:true->sql語句執行完畢后,可以事務提交;false->sql語句執行發送錯誤,事務進行回滾
    • Executor執行器對象:創建Statement對象,在創建過程中依靠MapperStatement對象將賦值內容與sql占位符進行綁定處理
  • SqlSession.commit():此時根據dirty屬性絕對提交和回滾
  • SqlSession.close():


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM