Eclipse利用Maven快速上手搭建MyBatis

  • 2019 年 10 月 7 日
  • 筆記

一、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

 1     <dependencies>   2         <!-- 添加MyBatis框架3.4.6版本 -->   3         <dependency>   4             <groupId>org.mybatis</groupId>   5             <artifactId>mybatis</artifactId>   6             <version>3.4.6</version> <!-- 版本号视情况修改 -->   7         </dependency>   8         <!-- 添加MySql驱动包 -->   9         <dependency>  10             <groupId>mysql</groupId>  11             <artifactId>mysql-connector-java</artifactId>  12             <version>5.1.25</version>  13         </dependency>  14     </dependencies>

  2.5、创建XML配置MyBatis

 

 1 <?xml version="1.0" encoding="UTF-8"?>   2 <!DOCTYPE configuration   3   PUBLIC "-//mybatis.org//DTD Config 3.0//EN"   4   "http://mybatis.org/dtd/mybatis-3-config.dtd">   5 <configuration>   6     <environments default="development">   7         <environment id="development">   8             <transactionManager type="JDBC" />   9             <dataSource type="POOLED">  10                 <property name="driver" value="com.mysql.jdbc.Driver" /> <!-- 驱动类型 -->  11                 <property name="url" value="jdbc:mysql://localhost:3306/sam" /> <!-- 连接字符串 -->  12                 <property name="username" value="root" /> <!-- 用户名 -->  13                 <property name="password" value="root" /> <!-- 密码 -->  14             </dataSource>  15         </environment>  16     </environments>  17     <mappers>  18         <mapper resource="DeptMapper.xml" /> <!-- 映射SQL语句的XML文件 -->  19     </mappers>  20 </configuration>

  2.6、创建XML映射SQL语句

 1 <?xml version="1.0" encoding="UTF-8"?>   2 <!DOCTYPE mapper   3   PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"   4   "http://mybatis.org/dtd/mybatis-3-mapper.dtd">   5 <mapper namespace="Dept">   6     <!-- 插入单个部门信息 -->   7     <insert id="InsertDept">   8         INSERT INTO DEPT (DNAME,LOC)   9         VALUES (#{DName},#{Loc})  10     </insert>  11 </mapper>

CRUD语法

 1 <insert id="insertAuthor">   2   insert into Author (id,username,password,email,bio)   3   values (#{id},#{username},#{password},#{email},#{bio})   4 </insert>   5   6 <update id="updateAuthor">   7   update Author set   8     username = #{username},   9     password = #{password},  10     email = #{email},  11     bio = #{bio}  12   where id = #{id}  13 </update>  14  15 <delete id="deleteAuthor">  16   delete from Author where id = #{id}  17 </delete>

  2.7、创建实体类

表结构

 1 package com.chenyanbin;   2   3 public class Dept {   4     //部门名称   5     private String DName;   6     //部门位置   7     private String Loc;   8     public String getDName() {   9         return DName;  10     }  11     public void setDName(String dName) {  12         DName = dName;  13     }  14     public String getLoc() {  15         return Loc;  16     }  17     public void setLoc(String loc) {  18         Loc = loc;  19     }  20 }

  2.8、创建Main函数

 1 package com.chenyanbin;   2   3 import java.io.IOException;   4 import java.io.InputStream;   5 import org.apache.ibatis.io.Resources;   6 import org.apache.ibatis.session.SqlSession;   7 import org.apache.ibatis.session.SqlSessionFactory;   8 import org.apache.ibatis.session.SqlSessionFactoryBuilder;   9  10 public class TestMain {  11     public static void main(String[] args) throws IOException {  12         //创建实体类  13         Dept dept = new Dept();  14         dept.setDName("上海事业部");  15         dept.setLoc("上海");  16         //加载XML文件  17         InputStream is = Resources.getResourceAsStream("myBatis-config.xml"); //加载MyBatis的配置文件  18         //初始化SqlSessionFactory  19         SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);  20         SqlSession session = factory.openSession();  21         session.insert("InsertDept", dept);  22         session.commit();  23         session.close();  24     }  25 }

 

  

  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