Eclipse利用Maven快速上手搭建MyBatis

摘要:
Maven除了以程序构建能力为特色之外,还提供高级项目管理工具。由于Maven的缺省构建规则有较高的可重用性,所以常常用两三行Maven构建脚本就可以构建简单的项目。由于Maven的面向项目的方法,许多ApacheJakarta项目发文时使用Maven,而且公司项目采用Maven的比例在持续增长。--添加MySql驱动包--˃mysqlmysql-connector-java5.1.25  2.5、创建XML配置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

Eclipse利用Maven快速上手搭建MyBatis第1张

  2.3、Maven与Eclipse关联

Eclipse利用Maven快速上手搭建MyBatis第2张

  2.4、创建Maven项目,并配置pom.xml

Eclipse利用Maven快速上手搭建MyBatis第3张

     <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

Eclipse利用Maven快速上手搭建MyBatis第4张

 <?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语句

Eclipse利用Maven快速上手搭建MyBatis第5张

 <?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、创建实体类

表结构

Eclipse利用Maven快速上手搭建MyBatis第6张

 package com.chenyanbin;
 
 public classDept {
     //部门名称
     privateString DName;
     //部门位置
     privateString Loc;
     publicString getDName() {
         returnDName;
 }
     public voidsetDName(String dName) {
         DName =dName;
 }
     publicString getLoc() {
         returnLoc;
 }
     public voidsetLoc(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 classTestMain {
     public static voidmain(String[] args) throws IOException {
         //创建实体类
         Dept dept = newDept();
         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();
 }
 }

Eclipse利用Maven快速上手搭建MyBatis第7张

Eclipse利用Maven快速上手搭建MyBatis第8张

  2.9、项目文件目录图

Eclipse利用Maven快速上手搭建MyBatis第9张

以上配置完成,但是博主碰到一个问题,数据库保存进去了,程序警告,警告如下:

Eclipse利用Maven快速上手搭建MyBatis第10张

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():

免责声明:文章转载自《Eclipse利用Maven快速上手搭建MyBatis》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇pytest框架之allure报告生成用Nexus做Maven私服全攻略下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Hibernate中批量保存数据

第一种方式 public void saveCus(final List<Cus> cuss) { this.getHibernateTemplate().execute(new HibernateCallback() { @Override public Object doInHibernate(Session sessi...

java学习笔记hibernate基础(1)

hibernate基础1.hibernate介绍与动手入门体验  问题:模型不匹配(java对象模型与数据库关系模型不匹配)  解决: 1.使用JDBC手工转换        2.使用ORM(Object Relation Mapping对象关系映射)框架,有Hibernate,TopLink,OJB  下载地址http://www.hibernate.o...

Phoenix 使用教程

引言 hbase 提供很方便的 shell 脚本,可以对数据表进行 CURD 操作,但是毕竟是有一定的学习成本的,基本上对于开发来讲,sql 语句都是看家本领,那么,有没有一种方法可以把 sql 语句转换成 hbase的原生API呢? 这样就可以通过普通平常的 sql 来对hbase 进行数据的管理,使用成本大大降低。 Apache Phoenix 组件就...

Spring+SpringMVC+MyBatis深入学习及搭建(八)——MyBatis查询缓存

转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6956206.html  前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(七)——MyBatis延迟加载 1.什么是查询缓存 mybatis提供查询缓存,用于减轻数据库压力,提高数据库性能。 mybatis提供一级缓存和二级缓存。 一级缓存...

Tomcat7基于Redis的Session共享实战一

本文主要介绍如何使用redis对tomcat7的session进行托管。 1、安装Redisredis安装比较简单,此处略过。 2、配置两个Tomcat在本机上配置两个Tomcat,分别为tomcat7-8081、tomcat7-8082。 编制两个index.jsp页面,分别放入tomcat7-8081webappsROOT、tomcat7-8082we...

Linux系统终端session保持服务工具-Tmux

Tmux是非常流行的终端复用软件,通过一个终端登录远程主机并运行tmux后,在其中可以开启多个控制台而无需再“浪费”多余的终端来连接这台远程主机。相对于Screen,它更加先进:支持屏幕切分,而且具备丰富的命令行参数,使其可以灵活、动态的进行各种布局和操作。对于Tmux的使用,可以参考:Tmux终端复用详解 Tmux 可用于在一个终端窗口中运行多个终端会话...