转自:http://ccchhhlll1988-163-com.iteye.com/blog/1415621

基本目的:利用Mybatis完成对一个表简单的select、insert、update、delete操作。达到熟悉MyBatis基本用法的目的。 
用到的jar:MyBatis.jar,数据库驱动.jar(如mysql-connector.jar)

MyBatis的配置文件MyBatisConfig.xml。可以进行数据源和事务管理器的配置,以及其他影响MyBatis执行的变量

MyBatisConfig.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>
 <!-- 引入外部文件 -->
 <properties resource="config.properties"></properties>
 <!-- end properties -->
 <!-- 定义vo --> 
    <typeAliases>
        <typeAlias alias="User" type="com.mybatis.test.vo.User" />
    </typeAliases>
 <!-- end define -->
 <environments default="development">
  <environment id="development">
   <transactionManager type="JDBC" />
   <dataSource type="POOLED">
    <property name="driver" value="${driver}" />
    <property name="url" value="${url}" />
    <property name="username" value="${username}" />
    <property name="password" value="${password}" />
   </dataSource>
  </environment>
 </environments>
 <mappers>
  <mapper resource="com/mybatis/test/maps/UserMapper.xml" />
 </mappers>
</configuration>

MyBatis的映射文件UserMapper.xml。文档中评价这个文件时奇迹发生的地方:

UserMapper.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">
<mapper namespace="com.mybatis.test.dao.UserDAO">
 <select id="selectUser" parameterType="int" resultType="User">
  select *
  from user where id = #{id}
 </select>
 <select id="selectAllUser" resultType="User">
  select id, username from
  user
 </select>
 <insert id="insertUser" parameterType="User">
  insert into user(username)
  values ( #{username})
 </insert>
 <update id="updateUser" parameterType="User">
  update user set
  username=#{username}, password=#{password} where id = #{id}
 </update>
 <delete id="deleteUser" parameterType="User">
  delete from user where
  username=#{username} and password=#{password}
 </delete>
</mapper>

UserMapper接口文件,该文件与UserMapper.xml有着某些地方一一对应的关系,注意哦。

代码:

package com.mybatis.test.dao;
import java.util.List;
import com.mybatis.test.vo.User;
public interface UserDAO {
    public User selectUser(int id);
    public List<User> selectAllUser();
    public int insertUser(User user);
    public void updateUser(User user);
    public void deleteUser(User user);
}

MyBatis文件,其中定义了产生SqlSessionFactory的工厂单例类。

代码:

package com.mybatis.test.util;
import java.io.IOException;
import java.io.Reader;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
/**
 * @author chl 工厂单例模式,生成SqlSessionFactory实例。
 *
 */
public class MyBatis {
    private MyBatis() {
    };
    private static SqlSessionFactory ssf = null;
    public static SqlSessionFactory getSessionFactory() throws IOException {
        if (null == ssf) {
            String resource = "mybatisConfig.xml";
            Reader reader = Resources.getResourceAsReader(resource);
            ssf = new SqlSessionFactoryBuilder().build(reader);
        }// if
        return ssf;
    }
}

User文件,定义了User javabean实体类。

package com.mybatis.test.vo;


public class User {
    private int id;
    private String username;
    private String password;


public int getId() {
        return id;
    }


public void setId(int id) {
        this.id = id;
    }


public String getUsername() {
        return username;
    }


public void setUsername(String username) {
        this.username = username;
    }


public String getPassword() {
        return password;
    }


public void setPassword(String password) {
        this.password = password;
    }


@Override
    public String toString() {
        return "id is:" + id + " name is: " + username;
    }
}


userAction类,方法体中获取SqlSessionFactory实例,获得SqlSession,获取SqlMapper,然后调用映射的方法。

package com.mybatis.test.util;

import java.io.IOException;
import java.util.List;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;

import com.mybatis.test.dao.UserDAO;
import com.mybatis.test.vo.User;

/**
 * @author chl 对user的操作。 其中将SqlSession放于方法级范围。
 */
public class UserAction {


public void insert(User user) {
        SqlSessionFactory ssf = null;
        SqlSession session = null;
        try {
            ssf = MyBatis.getSessionFactory();
            session = ssf.openSession(true);// 设定事务自动提交(方式一)
            UserDAO userDAO = session.getMapper(UserDAO.class);


userDAO.insertUser(user);
            selectAll();
            System.out.println("==================================");
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (null != session) {
                session.close();
                session = null;
            }
        }


}


public void update(User user) {
        SqlSessionFactory ssf = null;
        SqlSession session = null;
        try {
            ssf = MyBatis.getSessionFactory();
            session = ssf.openSession();
            UserDAO userDAO = session.getMapper(UserDAO.class);


userDAO.updateUser(user);


session.commit();// 设定事务自动提交(二)
            selectAll();
            System.out.println("==================================");
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (null != session) {
                session.close();
                session = null;
            }
        }
    }


public void selectAll() {
        SqlSessionFactory ssf = null;
        SqlSession session = null;
        try {
            ssf = MyBatis.getSessionFactory();
            session = ssf.openSession();
            UserDAO userDAO = session.getMapper(UserDAO.class);


List<User> users = userDAO.selectAllUser();
            for (User u : users) {
                System.out.println(u.getUsername() + "    " + u.getId());
            }


System.out.println("session is null? " + (session == null));
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (null != session) {
                session.close();
                session = null;
            }
        }
    }


public void delete(User user) {
        SqlSessionFactory ssf = null;
        SqlSession session = null;


try {
            ssf = MyBatis.getSessionFactory();
            session = ssf.openSession(true);
            UserDAO userDAO = session.getMapper(UserDAO.class);
            userDAO.deleteUser(user);


selectAll();
            System.out.println("==================================");
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (null != session) {
                session.close();
                session = null;
            }
        }
    }


public static void main(String[] args) {
        UserAction userAction = new UserAction();


User user = new User();
        user.setUsername("horizon");
        user.setPassword("123456");
        userAction.delete(user);
    }
}


config.properties代码:

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/tt
username=root
password=root

这是参照转载的网站代码修正的,转载的事务处理有点问题,在此进行了修改.....

MyBatis学习练习的更多相关文章

  1. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...

  2. MyBatis学习总结(八)——Mybatis3.x与Spring4.x整合(转载)

      孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(八)--Mybatis3.x与Spring4.x整合 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: m ...

  3. MyBatis学习总结(七)——Mybatis缓存(转载)

      孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(七)--Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的 ...

  4. (原创)mybatis学习二,spring和mybatis的融合

    mybatis学习一夯实基础 上文介绍了mybatis的相关知识,这一节主要来介绍mybaits和spring的融合 一,环境搭建 1,jar包下载,下载路径为jar包 2,将包导入到java工程中 ...

  5. (原创)mybatis学习一,夯实基础

    一,what?(是什么) MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可 ...

  6. MyBatis学习--简单的增删改查

    jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...

  7. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  8. 【Todo】Mybatis学习-偏理论

    之前写过好几篇Mybatis相关的文章: http://www.cnblogs.com/charlesblc/p/5906431.html  <SSM(SpringMVC+Spring+Myba ...

  9. MyBatis学习系列三——结合Spring

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring MyBatis在项目中应用一般都要结合Spring,这一章主要把MyBat ...

  10. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

随机推荐

  1. bzoj 2038 [2009国家集训队]小Z的袜子(hose)(莫队算法)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2038 [题意] 给定一个有颜色的序列,回答若干个询问:区间内任选两个颜色相同的概率. ...

  2. 黑马程序员——Foundation中的OC结构体

    <span style="font-size:14px">------<a target="_blank" href="http:/ ...

  3. Connection failed: NT_STATUS_ACCOUNT_RESTRICTION

    今天在linux机器上想要远程重启一台window的机器,输入命令后报错,如下 Google了下,有说是window禁止远程空密码登录,于是到window系统中添加了密码,这下再运行 这下执行就正常了

  4. sql统计重复数据

    sql代码如下: 统计重复的数据 select MingCheng from tabShouFeiGongShi group by MingCheng having count(MingCheng) ...

  5. ps做gif love教程(转)

    先看看效果吧: 这是在写部教程的时候,看到一个由方格组成的心.于是试着用PS做成了动画,然后加入了LOVE四个字母,看起来还可以.但是,有些复杂.复杂倒不是技术上的复杂,是做起来复杂. 来试试吧. 1 ...

  6. BFS寻路算法的实现

    关于BFS的相关知识由于水平有限就不多说了,感兴趣的可以自己去wiki或者其他地方查阅资料. 这里大概说一下BFS寻路的思路,或者个人对BFS的理解: 大家知道Astar的一个显著特点是带有启发函数, ...

  7. SharePoint咨询师之路:备份和恢复系列二 - 备份服务器场

    本系列包括: 备份服务器场和配置 备份web和服务应用程序 备份内容数据库 备份网站集 备份自定义项 根据“SharePoint咨询师之路:备份和恢复系列--制定备份计划”我们制定了一下备份计划如下: ...

  8. 转】MyEclipse使用总结——MyEclipse去除网上复制下来的来代码带有的行号

    原博文出自于: http://www.cnblogs.com/xdp-gacl/p/3544208.html 感谢! 一.正则表达式去除代码行号 作为开发人员,我们经常从网上复制一些代码,有些时候复制 ...

  9. HTML5每日一练之figure新标签的应用

    igure元素是一种元素的组合,可带有标题(可选).figure标签用来表示网页上一块独立的内容,将其从网页上移除后不会对网页上的其他内容产生影响.figure所表示的内容可以是图片.统计图或代码示例 ...

  10. LightOJ 1259 Goldbach`s Conjecture (哥德巴赫猜想 + 素数筛选法)

    http://lightoj.com/volume_showproblem.php?problem=1259 题目大意:给你一个数n,这个数能分成两个素数a.b,n = a + b且a<=b,问 ...