mybatis是一个持久层框架,其主要思想就是想将程序中大量的SQL语句剥离出来,配置在配置文件中,实现SQL的灵活配置.

使得SQL与程序代码分离,即在不修改程序代码的情况下,直接在配置文件中修改SQL.

mybatis的搭建步骤

下载jar包并部署包

  mybatisjar下载网址:https://github.com/mybatis/mybatis-3/releases,mybatis压缩包解压后结构目录如下

此外lib目录下存放着编译依赖包如下

最后只需把jar包放入项目的此lib 目录下即可

或者选中项目右键 build path

进入此窗口

单击第二个按钮直接从本地进行添加jar,亦或者按下按钮从此工作空间的项目中选择jar进行添加

编写mybatis核心配置文件

在此之前需要调整下xml的代码提示(引入dtd文件)

  请先看第6点

  1. 选择window →  preferences
  2. 搜索xml →  xml catalog出现如下窗口
  3. add → file system 选择你所需要的文件dtd

    这两个文件都是经常使用的所以都添加进去

  4. key 需要与配置文件中的 此部分相同

    所以key是  -//mybatis.org//DTD Config 3.0//EN,那么dtd文件到哪里找呢?

  5. 所需的dtd文件都在mybatis解压后的 mybatis-3.4.4\org\apache\ibatis\builder\xml 下面如图

创建核心配置文件

  1. 找到如下窗口 → next
  2. 选择第一个 → next 
  3. 选择第二个 → 选择config → next→finish即可

  4. 此时创建好的xml文件便会自动生成如下代码

编写核心配置文件

  话不多说直接上代码

 <?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>
<!-- 引入database.propeerties -->
<properties resource="database.properties"/>
<!-- 配置mybatis的log实现log4j -->
<settings>
<setting name="logImpl" value="LOG4J"/>
</settings>
<typeAliases>
<package name="cn.smbms.pojo"/>
</typeAliases>
<!-- 配置mybatis多套运行环境 -->
<environments default="development">
<environment id="development">
<!-- 配置事物管理,采用jdbc的事物管理 -->
<transactionManager type="JDBC"/>
<!-- POOLED:mybatis自带的数据源,jndi:基于Tomcat的数据源 -->
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${user}"/>
<property name="password" value="${pwd}"/>
</dataSource>
</environment>
</environments>
<!-- 将mapper文件加入到配置文件中 -->
<mappers>
<mapper resource="cn/smbms/dao/UserMapper.xml"/>
</mappers>
</configuration>
属性 作用
configuration 配置文件的根元素节点
propertes 通过resource属性从外表知道properties属性文件,该属性文件描述数据库的相关配置
settings 设置mybatis运行中的一些行为,比如此处设置mybatis的log日志实现为LOG4J,即使用log4j实现日志功能
environments 表示配置mybatis的多套运行环境,将SQL映射到多个不同的数据库上,元素节点中可配置多个,但必须指定默认运行环境
environment 配置mybatis的一套运行环境,需指定运行环境id,事务管理,数据源配置等相关信息
mappers 作用是告诉mybatis去哪里找SQL映射文件(该内容是开发者定义的映射SQL语句),整个项目可以有1个或多个
mapper mappers的子元素节点,具体知道SQL映射文件的路径,其中resource属性表SQL映射文件的路径

创建实体类并为其创建DAO接口

  结构如下

创建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="cn.smbms.dao.UserMapper">
<!-- 查询用户表记录数 -->
<select id="count" resultType="int">
select count(1) as count from smbms_user
</select>
<!-- 查询用户列表 -->
<select id="getUserList" resultType="User">
select * from smbms_user
</select>
</mapper>
  1. mapper:映射文件的根元素节点,只有一个属性namespace
    1. namespace:用于区分不同的mapper,全局唯一.
  2. select:表示查询语句,是mybatis最常用的元素之一,常用属性如下
    1. id属性:改命名空间下唯一标识符
    2. resultType属性:表示SQL语句返回值类型,第一个select返回的是int,后者则是user类型

编写测试类运行

工具类代码如下

 package cn.smbms.utils;

 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 MyBatisUtil {
private static SqlSessionFactory factory;
static {
try {
//获取mybatis-config.xml文件的输出流
InputStream is=Resources.getResourceAsStream("mybatis-config.xml");
factory=new SqlSessionFactoryBuilder().build(is);
} catch (Exception e) {
e.printStackTrace();
}
} public static SqlSession createSqlSession() {
return factory.openSession(false); //默认true自带提交事务
}
public static void closeSqlSession(SqlSession sqlSession) {
if(null!=sqlSession) {
sqlSession.close();
}
}
}

测试类代码方法一 基于mapper接口方式操作如下

public static void main(String[] args) {
Logger logger = Logger.getLogger(Test.class);
SqlSession sqlSession =null;
List<User> userList = new ArrayList<>();
try {
sqlSession = MyBatisUtil.createSqlSession();
userList = sqlSession.getMapper(UserMapper.class).getUserList();
for (User user : userList) {
logger.debug("testGetUserList UserCode:"+user.getUserCode()+"and userName:"+user.getUserName());
}
} catch (Exception e) {
e.printStackTrace();
}finally {
MyBatisUtil.closeSqlSession(sqlSession);
}
}

基于mapper接口方式操作此接口必须对应select映射SQL语句中的id对应

测试类代码方法二 运行映射SQL语句

public static void main(String[] args) {
Logger logger = Logger.getLogger(Test.class);
SqlSession sqlSession =null;
List<User> userList = new ArrayList<>();
try {
sqlSession = MyBatisUtil.createSqlSession();
//直接运行已映射的SQL语句
userList = sqlSession.selectList("cn.smbms.dao.UserMapper.getUserList");
for (User user : userList) {
logger.debug("testGetUserList UserCode:"+user.getUserCode()+"and userName:"+user.getUserName());
}
} catch (Exception e) {
e.printStackTrace();
logger.error(e);
}finally {
MyBatisUtil.closeSqlSession(sqlSession);
}
}

 在使用SQLsession实例执行已映射的语句,没有与id所对应的方法也不会出错,即使UserMpper这个接口没有也不会影响运行结果.

mybatis的环境搭建的更多相关文章

  1. SSM(Spring+SpringMVC+Mybatis)框架环境搭建(整合步骤)(一)

    1. 前言 最近在写毕设过程中,重新梳理了一遍SSM框架,特此记录一下. 附上源码:https://gitee.com/niceyoo/jeenotes-ssm 2. 概述 在写代码之前我们先了解一下 ...

  2. 基于Maven的Spring + Spring MVC + Mybatis的环境搭建

    基于Maven的Spring + Spring MVC + Mybatis的环境搭建项目开发,先将环境先搭建起来.上次做了一个Spring + Spring MVC + Mybatis + Log4J ...

  3. mybatis学习:mybatis的环境搭建与入门

    一.mybatis的概述: mybatis是一个持久层框架,用java编写 它封装了jdbc操作的很多细节,使开发者只需要关注sql语句本身,而无需关注注册驱动,创建连接登繁杂过程 它使用了ORM思想 ...

  4. 阶段3 1.Mybatis_05.使用Mybatis完成CRUD_1 回顾Mybatis的环境搭建-实现查询所有功能

    先回顾Mybits的环境搭建,. 直接next 直接点击finish 创建好的项目. 所有东西都自己写不现实,约束文件的头部还是拷贝过来 导入依赖坐标,Mybits mysql的驱动 log4j 单元 ...

  5. 项目SpringMVC+Spring+Mybatis 整合环境搭建(2)-> 测试Spring+Mybatis 环境

    测试前期准备 第一步:创建easybuy数据库,设置utf-8格式 第二步:创建表test_tb CREATE TABLE `test_tb` ( `id` int(11) NOT NULL AUTO ...

  6. 【Mybatis】环境搭建

    SqlMapConfig.xml(MyBatis配置文件) <?xml version="1.0" encoding="UTF-8" ?> < ...

  7. Maven 项目使用mybatis的环境搭建-基于xml形式实现查询所有的功能

    首先了解一下什么是 MyBatis? MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集. ...

  8. mybatis的环境搭建以及问题

    1.mybatis中3个重要的类或者接口 1)SqlSessionFactoryBuilder类 用它来创建工厂对象,它重载了9次build()方法,我们常用build(inputstream)来创建 ...

  9. 阶段3 1.Mybatis_01.Mybatis课程介绍及环境搭建_06.mybatis的环境搭建

    创建实体类,实现Serializable接口 属性名和数据库的字段名保持一致 Date字段需要导入包 生成gettter和setter,再生成一个ToString的方法 创建持久层Dao 创建接口 里 ...

随机推荐

  1. 3 - EventLoop和线程模型-事件循环

    a). EventLoopGroup为每个新创建的channel分配一个EventLoop,多个channel对应一个EventLoop. b). 一个EventLoop由一个不变的thread驱动, ...

  2. Angular 8 发布

    原文地址:https://blog.angular.io/version-8-of-angular-smaller-bundles-cli-apis-and-alignment-with-the-ec ...

  3. net core 的Generic Host 之Generic Host Builder

    前言 通用Host(Generic Host) 与 web Host 不同的地方就是通用Host解耦了Http请求管道,使得通用Host拥有更广的应用场景.比如:消息收发.后台任务以及其他非http的 ...

  4. Maven的学习资料收集--(四)使用Maven构建Web项目-测试

    2014-08-04 23:21 2人阅读 评论(0) 收藏 编辑 删除   目录(?)[+]   [-] 在srcmainjava下新建一个Servlet 修改webxml 新建JSP 测试   在 ...

  5. 让zepto支持requirejs的方法

    window.Zepto = Zepto '$' in window || (window.$ = Zepto) if ( typeof define === "function" ...

  6. 用命令行的方式将本地项目上传到git

    1.(先进入项目文件夹)通过命令 git init 把这个目录变成git可以管理的仓库 git init 2.把文件添加到版本库中,使用命令 git add .添加到暂存区里面去,不要忘记后面的小数点 ...

  7. SpringMVC 返回自定义属性名

    SpringMVC 返回的属性名默认是小写驼峰形式的实体对象中的属性名,如 userID 属性名它会返回 userId. 如果接口方式之前已经定下来,这样前端按原来的方式取数据会读取失败的,那有没有方 ...

  8. java网络访问指定出口ip

    java网络访问指定出口ip Table of Contents 1. socket 2. apache httpclient 1 socket 可以在Socket构造函数中指定使用的本地ip,如: ...

  9. [荐]推荐一个shell学习的网站

    最近再用shell脚本,发现一个脚本学习的网站,非常好用,特此推荐一下. shell学习网站链接:http://c.biancheng.net/cpp/shell/

  10. ArcSDE空间数据库中SDE用户使用探讨 (转载)

    ArcSDE作为空间数据库解决方案,应用非常广泛,本短文将尝试描述SDE的工作机制,简要说明空间数据库中SDE用户的使用方法.ArcSDE如何工作ArcSDE属于中间件技术,其本身并不能够存储空间数据 ...