一、MyBatis引言

  1、基本概念

    MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。MyBatis是一个持久层框架,完成是对数据库的访问和操作。

  2、优点

    解决了JDBC访问数据库过程中存在的问题,他是对原有JDBC技术的封装。

    a、大量的代码冗余。

    b、手工处理ORM。

    c、没有对访问数据进行优化(没有cache)。

二、一个简单的Mybatis程序  

  1、环境搭建

    a、导入核心jar包,导入第三方依赖jar包,导入对应数据库的驱动jar包。

    b、引入配置文件

      (1)log4j.properties(日志配置文件)放置在src根下

      (2)mybatis-config.xml位置随意。

      (3)mapper文件(实现DAO接口)位置随意。

    c、初始化配置

      mybatis-config.xml的文件配置

    主要分为两大部分:1、数据库连接的相关参数。2、Mapper文件的注册。

    ps、别名typeAlias

    在配置文件中设置别名之后,在mapper文件中会舒服很多。

  2、MyBatis核心API

    a、Resource

      作用:读取MyBatis相关配置文件,打开IO。

      建议:因为频繁打开IO会很占用资源,所以建议一次性通过IO读取所有需要的数据。

    b、SqlSessionFactory

      作用:通过SqlSessionFactory这个工厂创建SqlSession。

      特点:该类是一个重量级资源,并且线程安全,应该保证每一个应用只创建一个。

    c、SqlSession

      作用:(1)根据程序员写的mapper文件,自动创建mapper文件所对应的java类(DAO接口的实现类)

         (2)SqlSession内部封装Connection对象(一一对应的关系)。

           (3)SqlSession控制事务。

  3、Mybatis开发步骤

    a、创建表table。

    b、创建对应的实体类entity。

    d、创建DAO接口。

    e、配置Mapper文件做DAO层的实现。

<mapper namespace="xxxx.mybatis.UserDao">
    <select id="queryUserById" parameterType="int" resultType="xxxx.mybatis.User">
        select id,name,password,birthday
        from t_user
        where id = #{id}
    </select>
</mapper>

    ps、namespace="xxxx.mybatis.UserDao"----->要实现的DAO接口的全限定名。

       id="queryUserById"----->DAO接口中要实现的方法名。

       parameterType="int"----->方法参数类型(可省略)。

       resultType="xxxx.mybatis.User"----->sql语句所查询结果所对应的entity类。

      #{id}----->方法传递的参数。

    f、mapper文件的注册(在mybatis-config.xml配置)

<mappers>
    <mapper resource="xxxx/mybatis/resources/UserDaoMapper.xml">
</mappers>

    ps、resource="xxxxxx"------->mapper文件的路径。

    g、通过API运行mybatis

//1、通过Resource读取MyBatis的配置文件(路径要写对)
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
//2、创建SqlSessionFactory
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//3、创建SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();
//4、通过sqlSession获取DAO的实现类
UserDao userDao = sqlSession.getMapper(UserDao.class);
//5、编码
User user = userDao.queryUserById(1);

三、单表操作的Mapper文件配置问题

  1、集合类型的返回值(如List<User>)

<select id="queryAllUsers" resultType="xxxx.mybaits.User">
    select * from t_user
</select>

//resultType属性设置为集合中的元素类型即可

  2、参数绑定 

    当DAO方法中只存在一个参数时,在mapper文件#{}中填写任意内容都可以识别。

    当DAO方法中存在多个参数时,有以下两种解决方案:

    a、以起始自0的下标#{0}#{1}#{2}来区分

      java类:

public interface UserDao{

    public User queryUser(String name,String password);

}

      mapper文件:

<mapper namespace="xxxxx.UserDao">

    <select id="queryUser" resultType="User">
        select * from t_user where name =#{0} and password = #{1}
    </select>

</mapper>

      这样书写,mybatis便会顺序识别,自动将name跟#{0}匹配,password跟#{1}匹配。

    b、通过注解来进行绑定(推荐)

      java类:

public interface UserDao{

    public User queryUser(@Param("name")String name,@Param("password")String password);

}

      mapper文件:

<mapper namespace="xxxxx.UserDao">

    <select id="queryUser" resultType="User">
        select * from t_user where name =#{name} and password = #{password}
    </select>

</mapper>

      这种写法类似于给参数起了一个名字,在mapper文件里直接通过所起的名字来对应。这种方法更加灵活。   

        

浅谈Mybatis(一)的更多相关文章

  1. 浅谈mybatis中的#和$的区别

    1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号.如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by "111&qu ...

  2. 浅谈Mybatis(三)

    一.动态SQL 1.sql片段 解决sql语句的冗余代码问题. <sql id="SELECT_T_USER"> select id,name,password,bir ...

  3. 浅谈 Mybatis中的 ${ } 和 #{ }的区别

    好了,真正做开发也差不多一年了.一直都是看别人的博客,自己懒得写,而且也不会写博客,今天就开始慢慢的练习一下写博客吧.前段时间刚好在公司遇到这样的问题. 一.举例说明 select * from us ...

  4. 浅谈mybatis如何半自动化解耦

    在JAVA发展过程中,涌现出一系列的ORM框架,JPA,Hibernate,Mybatis和Spring jdbc,本系列,将来研究Mybatis. 通过研究mybatis源码,可将mybatis的大 ...

  5. 浅谈Mybatis连接原理

    众所周知数据库连接的过程,但是最近面试的人(菜面菜),都说用的SSM框架,但是我问了一下,mybatis是怎么连接上mysql的,基本上都会说:配置好的,直接用了,今天我来抛砖引玉一下,欢迎拍砖! 什 ...

  6. 浅谈MyBatis缓存

    在谈论MyBatis的缓存之前,我们先说说它的延迟加载,所谓延迟加载, resultMap中的association和collection标签具有延迟加载的功能.延迟加载的意思是说,在关联查询时,利用 ...

  7. 浅谈Mybatis通用Mapper使用方法_java - JAVA

    文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习 对单表进行增删改查是项目中不可避免的需求,Mybatis的通用Mapper插件使这些操作变得简单 添加maven依赖 在 ...

  8. 浅谈mybatis如何半自动化解耦和ORM实现

    在JAVA发展过程中,涌现出一系列的ORM框架,JPA,Hibernate,Mybatis和Spring jdbc,本系列,将来研究Mybatis. 通过研究mybatis源码,可将mybatis的大 ...

  9. 浅谈Mybatis持久化框架在Spring、SSM、SpringBoot整合的演进及简化过程

    前言 最近开始了SpringBoot相关知识的学习,作为为目前比较流行.用的比较广的Spring框架,是每一个Java学习者及从业者都会接触到一个知识点.作为Spring框架项目,肯定少不了与数据库持 ...

随机推荐

  1. 浅谈hadoop中mapreduce的文件分发

    近期在做数据分析的时候.须要在mapreduce中调用c语言写的接口.此时就须要把动态链接库so文件分发到hadoop的各个节点上,原来想自己来做这个分发,大概过程就是把so文件放在hdfs上面,然后 ...

  2. 固定cell.imageView.image的大小

    cell.imageView.image的大小 会随着Cell的高度而变化,不同的图片显示的也不一样,在网上找了几种方法,简单方便的是下面这种: UIImage *icon = [UIImage im ...

  3. java对象的内存布局(二):利用sun.misc.Unsafe获取类字段的偏移地址和读取字段的值

    在上一篇文章中.我们列出了计算java对象大小的几个结论以及jol工具的使用,jol工具的源代码有兴趣的能够去看下.如今我们利用JDK中的sun.misc.Unsafe来计算下字段的偏移地址,一则验证 ...

  4. jQuery-瀑布流 布局 (处理页面滚动和AJAX加载延迟问题)

    瀑布流:这种布局适合于小数据块,每个数据块内容相近且没有侧重.通常,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部. 一.功能分析: 1.判断图片是否进入可视区域: 2.用AJAX ...

  5. DevExpress.XtraCharts.chartControl

    private Dictionary<string, double> chartPieDataDic = new Dictionary<string, double>(); p ...

  6. 8种排序算法的C#实现

    排序是将一个数据元素(或记录)的任意序列,重新排列成一个按关键字有序的序列.排序根据涉及的存储器的不同分为内部排序和外部排序:内部排序是指待排序记录存放在内存进行的排序过程:外部排序是指待排序记录的数 ...

  7. 第四课 Grid Control实验 GC Agent安装(第一台机器部署) 及卸载

    3.GC Agent安装(第一台机器部署) 安装Agent 拷贝agent,现在ocm2机器上查找agent.linux  查找文件的方法: find ./ -name agent*linux 把ag ...

  8. 异常 ORA-00257: archiver error. Connect internal only, until freed

    我oracle 是安装在linux 下. ORA-00257: archiver error. Connect internal only, until freed 得知是错误是由于归档日志(arch ...

  9. 对于windows窗口的标题菜单栏的操作——删除/禁用 最小最大话和关闭

    HWND hand = FindWindow(NULL, "计算器"); int nStyle = GetWindowLong(hand, GWL_STYLE);nStyle &a ...

  10. [整理]DLL延时加载 && 设置进程私有环境变量

    DLL延时加载鉴于静态和动态加载之间,即无需在代码中显示加载但它内队依然是动态加载的方式只是系统帮处理了.这样做好处是: 1. 可以加快启动时间(因为它是动态加载在需要的时间加载), 2. 减小编写L ...