简介:

  1、Mybatis  开源免费框架,原名叫iBatis,2010在google code,2013年迁移到github

  2、作用: 数据访问层框架

    2.1  底层是对JDBC的封装

  3、mybatis优点之一:

    3.1 使用mybatis时,不需要编写实现类,只需要写需要执行的sql命令。

环境搭建:

  1、导入jar                   (之前把mysql的驱动包放入tomcat中了,所有在这里没有导入mysql驱动包)

       

  2、在src下新建全局配置文件(编写JDBC四个变量)

     2.1 在src目录下新建xml文件  (src/mybatis.xml)

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration                  2-4是引入远程的DTD文件,进行代码的提示
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- default引用environment的id,当前所使用的环境 -->
<environments default="default">
<!-- 声明可以使用的环境 -->
<environment id="default">
<!-- 使用原生JDBC事务 -->
<transactionManager type="JDBC"></transactionManager>
<!-- 数据库的连接池 -->               配置JDBC四个变量
<dataSource type="POOLED">         
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/ssm"/>
<property name="username" value="root"/>
<property name="password" value="362222"/>
</dataSource>
</environment>
</environments>
21 <mappers>
22        <mapper resource="com/bjsxt/mapper/FlowerMapper.xml"/>
23    </mappers>  
</configuration>

   3、新建以mapper结尾的包,在包下新建:实体类名+Mapper.xml 的文件

    3.1  文件的作用: 编写需要执行的SQL语句

    3.2  把xml理解成实现类

        实现过程是:mybatis底层将xml文件解析反射成实现类进行数据操作  

    3.3  配置过程    (com/bjsxt/mapper/FlowerMapper.xml)

 <?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">
<!-- namesapce:理解成实现类的全路径(包名+类名) -->
<mapper namespace="a.b">
<!-- id:方法名
parameterType:定义参数类型
resultType:返回值类型 如果方法返回值是list,在resultType中写List的泛型,因为mybatis对
jdbc封装,一行一行读取数据
-->                 通过反射找到自定义的类  (查询的是List集合,为什么类型是自定义的类??因为底层是对JDBC封装的(ResultSet一次只能读取一行数据),一行数据是一个实体类)
<select id="sellAll" resultType="com.bjsxt.pojo.Flower">
select * from flower
</select>
</mapper>

   4、测试结果(只有在单独使用mybatis时使用,最后ssm整合时下面代码不需要编写)

    4.1 新建一个包一个类进行测试

      

 package com.bjsxt.test;

 import java.io.IOException;
import java.io.InputStream;
import java.util.List; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; import com.bjsxt.pojo.Flower; public class Test {
public static void main(String[] args) {
InputStream is = null;
try {
is = Resources.getResourceAsStream("mybatis.xml"); } catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//使用工厂设计模式
SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(is);
//生产SqlSession    SqlSession 封装了mybatis中所有的sql命令
SqlSession session=factory.openSession(); List<Flower> list = session.selectList("a.b.sellAll");
for(Flower flower:list){
System.out.println(flower.toString());
}
session.close();
}
}

  文件目录

        

环境搭建详解:

  1、全局配置文件中内容

      1.1  <transactionManager/> type 属性可取值

        1.1.1 JDBC事务管理使用JDBC原生事务管理方式

        1.1.2 MANAGED 把事务管理转交给其他容器  (spring使用)

                 原生JDBC事务 setAutoMapping(false);

       1.2  <dataSouce/> type属性

        1.2.1 POOLED 使用数据库连接池

        1.2.2 UNPOOLED  不使用数据库连接池,和直接使用JDBC一样

        1.2.3 JNDI : java命名目录接口技术,(使用java通过接口调用别的语言程序)

数据库连接池

      1、在内存中开辟一块空间,存放多个数据库连接对象。

      2、JDBC Tomcat Pool 直接由tomcat产生数据库连接池

      3、图示

        3.1 active 状态:当前连接对象被应用程序使用中

        3.2 ldle 空闲状态:等待应用程序使用

        

      4、使用数据库连接池的目的

         4.1  在高频率访问数据库时,使用数据库连接池可以降低服务器系统压力,提升程序运行效率。

          4.1.1 小型项目不适用数据库连接池

      5、实现JDBC tomcat Pool的步骤

            https://www.cnblogs.com/axu521/p/10056835.html    

 三种查询方式

    1、select()  返回值为List<resultType 属性控制>

      1.1  适用于查询结果都需要遍历的需求

 下面这是Test测试
1 List<Flower> list = session.selectList("a.b.sellAll");
for(Flower flower:list){
System.out.println(flower.toString());
} 下面只是FlowerMapper.xml文件
     <select id="sellAll" resultType="com.bjsxt.pojo.Flower">
         select * from flower
     </select>

      2、selectOne()  返回值Object

      2.1 适用于返回结果只是变量或一行数据时

  下面这是Test测试
1 int i=session.selectOne("a.b.selById");
System.out.println(i);   下面这是FlowerMapper.xml文件中
     <select id="selById" resultType="int">
         select count(*) from flower
     </select>

    3、selectMap()  返回值 Map

      3.1 适用于需求需要在查询结果中通过某列的值取到这行数据的需求

      3.2 Map<Key,resultType控制>

   下面这是Test测试    
//把数据库中哪个列的值当做map的key
Map<Object, Object> map = session.selectMap("a.b.c","name");
System.out.println(map);

  下面这是FlowerMapper.xml文件中
   <select id="c" resultType="com.bjsxt.pojo.Flower">
     select * from flower
     </select>

  

Mybatis简介、环境搭建和详解的更多相关文章

  1. 大数据学习系列之四 ----- Hadoop+Hive环境搭建图文详解(单机)

    引言 在大数据学习系列之一 ----- Hadoop环境搭建(单机) 成功的搭建了Hadoop的环境,在大数据学习系列之二 ----- HBase环境搭建(单机)成功搭建了HBase的环境以及相关使用 ...

  2. SpringMVC环境搭建和详解

    1.Spring容器和SpringMVC容器是父子容器 1.1 SpringMVC容器可以调用Spring容器中的所有内容 1.2 图示 2.SpringMVC环境搭建 1.导入jar包 2.在web ...

  3. visual studio 2015下使用gcc调试linux c++开发环境搭建完整详解

    一直以来,相信绝大部分的开发都是windows/mac下做开发,尤其是非嵌入式和qt系的,而开源服务器程序绝大部分都是跑在Linux下,几乎就没有跑在windows下的.一直以来开发人员都是在wind ...

  4. Jmeter(一) - 从入门到精通 - 环境搭建(详解教程)

    1.JMeter 介绍 Apache JMeter是100%纯JAVA桌面应用程序,被设计为用于测试客户端/服务端结构的软件(例如web应用程序).它可以用来测试静态和动态资源的性能,例如:静态文件, ...

  5. windows环境搭建jira 详解

    一.事前准备 1:JDK下载并安装:http://www.oracle.com/technetwork/java/javase/downloads/index.html2:MySQL JDBC连接驱动 ...

  6. 大数据学习系列之七 ----- Hadoop+Spark+Zookeeper+HBase+Hive集群搭建 图文详解

    引言 在之前的大数据学习系列中,搭建了Hadoop+Spark+HBase+Hive 环境以及一些测试.其实要说的话,我开始学习大数据的时候,搭建的就是集群,并不是单机模式和伪分布式.至于为什么先写单 ...

  7. idea spring+springmvc+mybatis环境配置整合详解

    idea spring+springmvc+mybatis环境配置整合详解 1.配置整合前所需准备的环境: 1.1:jdk1.8 1.2:idea2017.1.5 1.3:Maven 3.5.2 2. ...

  8. Quartz学习——SSMM(Spring+SpringMVC+Mybatis+Mysql)和Quartz集成详解(转)

    通过前面的学习,你可能大致了解了Quartz,本篇博文为你打开学习SSMM+Quartz的旅程!欢迎上车,开始美好的旅程! 本篇是在SSM框架基础上进行的. 参考文章: 1.Quartz学习——Qua ...

  9. Scala IDEA for Eclipse里用maven来创建scala和java项目代码环境(图文详解)

    这篇博客 是在Scala IDEA for Eclipse里手动创建scala代码编写环境. Scala IDE for Eclipse的下载.安装和WordCount的初步使用(本地模式和集群模式) ...

随机推荐

  1. openstack(Pike 版)集群部署(三)--- Glance 部署

    一.介绍 参照官网部署:https://docs.openstack.org/glance/queens/install/ 继续上一博客进行部署:http://www.cnblogs.com/weij ...

  2. 最短路 poj1125

    输入一个n表示有n个点,接下来n行,每行(假设是u)第一个数字m表示有m对数字(每一对两个数字v,w,表示u到v的时间w),后面接m对数字.找一个起点,它到其他点所花费的时间(求起点到其他点距离的最大 ...

  3. window中磁盘空间不足但是找不到使用空间的文件

    今天看到 电脑的  d盘 空间爆红,空间满了,去找了找没有找到具体是哪个文件占用的空间.一个一个文件的查看属性,都没有找到.文件都不大,几百个g的空间就没了.莫名其妙!!! 自己开启了备份还原,存储的 ...

  4. layer数据表格换行

    在使用layer数据表格的时候,默认是不可以换行的.这样显示 改动后 数据格式为   aa<br>bb就会显示为换行 比如我们的字符串是    a<br>b 这样的字符串浏览器 ...

  5. anaconda的安装tensorflow

    在anaconda prompt中我们输入 anaconda search -t conda tensorflow 查看能在哪里安装tensorflow anaconda show dhirschfe ...

  6. 162. Find Peak Element (Array; Divide-and-Conquer)

    A peak element is an element that is greater than its neighbors. Given an input array where num[i] ≠ ...

  7. TZOJ 5291 游戏之合成(快速幂快速乘)

    描述 zzx和city在玩一款小游戏的时候,游戏中有一个宝石合成的功能,需要m个宝石才可以合成下一级的宝石(例如需要m个1级宝石才能合成2级宝石). 这时候zzx问city说“我要合成A级宝石需要多少 ...

  8. Netty---入门程序,搭建Websocket 服务器

    Netty 常用的场景: 1.充当HTTP 服务器,但Netty 并没有遵循servlet 的标准,反而实现了自己的一套标准进行Http 服务: 2,RPC 远程调用,在分布式系统中常用的框架 3.S ...

  9. MyBatis延迟加载和缓存(4)

    一.项目创建 1.项目目录结构 2.数据库配置和上一篇的一样,这里不再描述.下面创建mybatis配置文件SqlMapConfig.xml <?xml version="1.0&quo ...

  10. stark组件开发之自动生成URL

    app01\model.py from django.db import models # Create your models here. class Depart(models.Model): i ...