mybatis比较轻量,适合开发比较小型的或者业务比较复杂的系统;

相对于hibernate来说可以灵活的写sql,更灵活的处理遇到的业务逻辑;

可以说hibernate是pojo实体对db的orm映射,而mybatis是pojo对sql的映射;

作为入门,先不考虑高级的特性,速度来一个CRUD再从源码和一个具体的业务来研究它的原理和高级特性;

CRUD基本思路:作为一种比较流行的持久层ORM框架,相当于三层架构中的dao层;

最终作为程序员的我们使用的SqlSession对象,先来个思路,再来个实现,最后研究细节;

环境准备,结合springmvc,做一个对博客文章的crud,下面贴出配置文件先;

第一列是依赖文件,都是在仓库中找到的最新的来用,兼容性如何暂且不管,先把简单的例子弄出来是关键;

第二列是web.xml的配置文件,定义一个spring的容器和mvc的url代理servlet;

第三列才是mybatis的使用环境准备,结合上图,上下往上推导定义出SqlSessionFactory,再定义出datasource和mapper配置文件;

第四列是springmvc的配置文件,相当常见,这里不解释;

<dependency>
     <groupId>org.springframework</groupId>
     <artifactId>spring-webmvc</artifactId>
     <version>4.0.1.RELEASE</version>
</dependency>

<dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-jdbc</artifactId>
         <version>4.0.1.RELEASE</version>
     </dependency>

<dependency>
         <groupId>org.mybatis</groupId>
         <artifactId>mybatis</artifactId>
         <version>3.2.4</version>
     </dependency>

<dependency>
         <groupId>org.mybatis</groupId>
         <artifactId>mybatis-spring</artifactId>
         <version>1.2.2</version>
     </dependency>

<!-- 数据源和jdbc驱动依赖 start-->
     <dependency>
         <groupId>commons-dbcp</groupId>
         <artifactId>commons-dbcp</artifactId>
         <version>1.4</version>
     </dependency>
     <dependency>
         <groupId>commons-pool</groupId>
         <artifactId>commons-pool</artifactId>
         <version>1.6</version>
     </dependency>

<dependency>
         <groupId>mysql</groupId>
         <artifactId>mysql-connector-java</artifactId>
         <version>5.1.29</version>
     </dependency>

<dependency>
         <groupId>com.google.guava</groupId>
         <artifactId>guava</artifactId>
         <version>15.0</version>
     </dependency>

<!--log4j日志框架-->
     <dependency>
         <groupId>log4j</groupId>
         <artifactId>log4j</artifactId>
         <version>1.2.17</version>
     </dependency>

<dependency>
         <groupId>javax.servlet</groupId>
         <artifactId>jstl</artifactId>
         <version>1.2</version>
     </dependency>
     <dependency>
         <groupId>javax.servlet</groupId>
         <artifactId>jsp-api</artifactId>
         <version>2.0</version>
         <scope>provided</scope>
     </dependency>

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
         version="3.0">
    <display-name>mybatis</display-name>
    <!--spring容器配置-->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:config/context-config.xml</param-value>
    </context-param>

<listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

<!--mvc配置-->
    <servlet>
        <servlet-name>mvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:config/dispatcher-config.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>mvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

</web-app>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
     <property name="driverClassName" value="${jdbc.mysql.driverClassName}"/>
     <property name="url" value="${jdbc.mysql.url}"/>
     <property name="username" value="${jdbc.mysql.username}"/>
     <property name="password" value="${jdbc.mysql.password}"/>
     <property name="maxActive" value="${jdbc.mysql.maxActive}"/>
     <property name="maxIdle" value="${jdbc.mysql.maxIdle}"/>
     <property name="initialSize" value="${jdbc.mysql.initialSize}"/>
     <property name="maxWait" value="${jdbc.mysql.maxWait}"/>
</bean>

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
     <property name="dataSource" ref="dataSource" />
</bean>

<context:component-scan base-package="com.sz.mybatis.framework.service">
     <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>

<context:annotation-config />

<tx:annotation-driven />

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean" scope="singleton" >
     <property name="dataSource" ref="dataSource" />
     <property name="typeAliasesPackage" value="com.sz.mybatis.framework.domain.blog" />
     <property name="mapperLocations">
          <list>
              <value>classpath:com/sz/mybatis/framework/persist/BlogMapper.xml</value>
          </list>
     </property>
</bean>

<bean id="sqlSession" factory-bean="sqlSessionFactory" factory-method="openSession" scope="prototype"></bean>

<context:component-scan base-package="com.sz.mybatis.admin.controller">
     <!--<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>-->
</context:component-scan>
<mvc:default-servlet-handler/>

<mvc:annotation-driven/>

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
     <property name="suffix" value=".jsp"></property>
     <property name="prefix" value="/page/"></property>
     <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
     <!--<property name="contentType" value="UTF-8"/>-->
</bean>

来一个博客对象的增删改查先;controller先来,这是概要;

然后是url映射:

servic直接略过,主要关注dao的实现,先来个接口先;

实现:

package com.sz.mybatis.framework.service.impl;

import com.google.common.collect.ImmutableList;
import com.sun.deploy.association.utility.AppConstants;
import com.sz.mybatis.framework.domain.Msg;
import com.sz.mybatis.framework.domain.PageConfig;
import com.sz.mybatis.framework.domain.blog.Blog;
import com.sz.mybatis.framework.persist.BlogDao;
import com.sz.mybatis.framework.persist.BlogMapper;
import com.sz.mybatis.framework.service.BlogService;
import com.sz.mybatis.framework.util.SystemConstant;
import org.apache.ibatis.session.SqlSession;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

/**
* Created with IntelliJ IDEA.
* User: cutter.li
* Date: 14-2-28
* Time: 下午3:07
* 服务实现类
*/
@Service
public class BlogServiceBean implements BlogService {

@Autowired
    SqlSession session;

private BlogMapper getBlogMapper() {
        return session.getMapper(BlogMapper.class);
    }

@Override
    public Msg list(PageConfig pageConfig) {
        if (pageConfig != null) {
            BlogMapper blogMapper = getBlogMapper();
            List<Blog> blogList= blogMapper.list(pageConfig);

Msg msg=new Msg();
            if(blogList!=null)
            {
                msg.setCode(SystemConstant.SUCCESS);
                msg.setMessage(SystemConstant.SUCCES_MESSAGE);
                msg.setData(blogList);
            }
            return msg;
        }
        return null;
    }

@Override
    public Blog listSingle(int id) {
        if (id > 0) {
            BlogMapper blogMapper = getBlogMapper();
            Blog blog = blogMapper.selectBlog(id);
            return blog;
        }
        return null;
    }

@Override
    public void modify(Blog blog) {
        getBlogMapper().updateBlog(blog);
    }

@Override
    public void insert(Blog blog) {
        getBlogMapper().insertBlog(blog);
    }

@Override
    public void remove(int id) {
        getBlogMapper().deleteBlog(id);
    }
}

配置文件:

<?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="com.sz.mybatis.framework.persist.BlogMapper">
    <select id="selectBlog" resultType="Blog">
    select * from Blog where id = #{id}
  </select>

<select id="list" parameterType="com.sz.mybatis.framework.domain.PageConfig" resultType="com.sz.mybatis.framework.domain.blog.Blog">
        select * from Blog  order by #{sortField} #{sortOrder}  limit  #{start},#{pageSize}
    </select>

<insert id="insertBlog" parameterType="Blog">
         insert into Blog (title,contentSummary,contentDetail) values(#{title},#{contentSummary},#{contentDetail})
     </insert>

<update id="updateBlog" parameterType="Blog">
        update Blog set title=#{title} , contentSummary=#{contentSummary} ,contentDetail=#{contentDetail} where id=#{id}
    </update>

<delete id="deleteBlog" parameterType="int">
        delete from Blog where id=#{id}
    </delete>
</mapper>

一个接口方法对应一条配置,通过id对应起来,据说可以在类的注解上面写sql,那会更简单,有空我改成注解的,敬请期待…

来几张效果图先:

两个图对比标识完成了分页的操作;

两个图对比表示实现了增加的功能;

两个图对比表示实现了编辑的功能;

最后标识实现了删除的功能;

到这里crud的程序算完成了,mybatis成功的入门了…

对了,附上源码...

mybatis笔记1 基本的配置和操作的更多相关文章

  1. MyBatis笔记二:配置

    MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...

  2. 【MyBatis笔记】mapper文件的配置以及说明

    <!doctype html>[MyBatis笔记]mapper文件的配置以及说明 figure:last-child { margin-bottom: 0.5rem; } #write ...

  3. spring+mybatis的多源数据库配置实战

    前言: 关于spring+mybatis的多源数据库配置, 其实是个老生常谈的事情. 网上的方案出奇的一致, 都是借助AbstractRoutingDataSource进行动态数据源的切换. 这边再无 ...

  4. MyBatis笔记一:GettingStart

    MyBatis笔记一:GettingStart 1.MyBatis优点 我们的工具和各种框架的作用就是为了我们操作数据库简洁,对于一些数据库的工具能帮我们少写一些处理异常等等的代码,但是他们并不是自动 ...

  5. 初识Mybatis框架,实现增删改查等操作(动态拼接和动态修改)

    此第一次接触Mybatis框架确实是有点不适应,特别是刚从Hibernate框架转转型过来,那么为什么要使用Mybatis框架,Mybatis框架和Hibernate框架又有什么异同呢? 这个问题在我 ...

  6. MyBatis Generator自动生成的配置及使用

    注意:文件名不能有中文字符,不然不能自动生成 找到MyBatis Generator.rar\MyBatis Generator\eclipse里的features和plugins文件,把这两个文件复 ...

  7. 安卓第十一天笔记-Intent与inter-filter配置

    安卓第十一天笔记-Intent与inter-filter配置 Intent与inter-filter配置 1.Intent对象简述 Android应用中有包含三种重要组件:Activity,Servi ...

  8. 初识Mybatis框架,实现增删改查等操作

    此第一次接触Mybatis框架确实是有点不适应,特别是刚从Hibernate框架转转型过来,那么为什么要使用Mybatis框架,Mybatis框架和Hibernate框架又有什么异同呢? 这个问题在我 ...

  9. thinkphp学习笔记4—眼花缭乱的配置

    原文:thinkphp学习笔记4-眼花缭乱的配置 1.配置类别 ThinkPHP提供了灵活的全局配置功能,ThinkPHP会依次加载管理配置>项目配置>调试配置>分组配置>扩展 ...

随机推荐

  1. Android实现TCP断点上传,后台C#服务实现接收

    终端实现大文件上传一直都是比较难的技术,其中涉及到后端与前端的交互,稳定性和流量大小,而且实现原理每个人都有自己的想法,后端主流用的比较多的是Http来实现,因为大多实现过断点下载.但稳定性不能保证, ...

  2. C# BackgroundWorker 详解

    在C#程序中,经常会有一些耗时较长的CPU密集型运算,如果直接在 UI 线程执行这样的运算就会出现UI不响应的问题.解决这类问题的主要途径是使用多线程,启动一个后台线程,把运算操作放在这个后台线程中完 ...

  3. WPF 普通属性变化通知

    问题描述:使用ObservableCollection<OrderItem> source 给Datagrid.ItemsSource赋值,在后台更新source集合后,前台Datagri ...

  4. WCF基础

    初入职场,开始接触C#,开始接触WCF,那么从头开始学习吧,边学边补充. SOA Service-Oriented Architecture,面向服务架构,粗粒度.开放式.松耦合的服务结构,将应用程序 ...

  5. Java列表

    Java列表踩过的坑 其中subList是RandomAccessSubList,不是序列化的列表,不可以加入tair. 加入tair测试代码 @Autowired private CacheMana ...

  6. 2016年中国微信小程序专题研究报告

    2016年12月29日,全球领先的移动互联网第三方数据挖掘和分析机构iiMedia Research(艾媒咨询)权威首发<2016年中国微信小程序专题研究报告>. 报告显示,82.6%手机 ...

  7. 我的MYSQL学习心得(十) 自定义存储过程和函数

    我的MYSQL学习心得(十) 自定义存储过程和函数 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心 ...

  8. 我的MYSQL学习心得(十七) 复制

    我的MYSQL学习心得(十七) 复制 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据 ...

  9. mono for android 获取手机照片或拍照并裁剪保存

    axml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android ...

  10. .NET跨平台:在Ubuntu上用自己编译的dnx运行ASP.NET 5示例程序

    在 Linux Ubuntu 上成功编译 dnx 之后,会在 artifacts/build/ 文件夹中生成 dnx-coreclr-linux-x64/ 与 dnx-mono/ 这2个文件夹,前者是 ...