所需要jar包:mybatis-3.x.x.jar 、如果需要和spring整合,还需要加入相关的包

1:看项目目录 红颜色不要关心

2:按照步骤:

1:加入jar包

2:创建数据源(configuration.xml)创建数据库(此处省略)

[html]view plaincopyprint?

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE configuration    
  3.     PUBLIC "-//mybatis.org//DTD Config 3.0//EN"    
  4.     "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6. <typeAliases>
  7. <!--给实体类起一个别名 user -->
  8. <typeAlias type="com.forum.po.User" alias="User" />
  9. </typeAliases>
  10. <!--数据源配置  这块用 BD2数据库 -->
  11. <environments default="development">
  12. <environment id="development">
  13. <transactionManager type="jdbc" />
  14. <dataSource type="POOLED">
  15. <property name="driver" value="com.ibm.db2.jcc.DB2Driver" />
  16. <property name="url" value="jdbc:db2://localhost:50000/forum" />
  17. <property name="username" value="DB2ADMIN" />
  18. <property name="password" value="admin" />
  19. </dataSource>
  20. </environment>
  21. </environments>
  22. <mappers>
  23. <!--userMapper.xml装载进来  同等于把“dao”的实现装载进来 -->
  24. <mapper resource="myBatis/userMapper.xml" />
  25. </mappers>
  26. </configuration>

3:创建实体类USER

[java]view plaincopyprint?

  1. package com.forum.po; 
  2. /**
  3. * 用户类
  4. *
  5. * @author db2admin
  6. *
  7. */
  8. public class User extends Entity { 
  9. private String name; 
  10. private Integer age; 
  11. public String getName() { 
  12. return name; 
  13.     } 
  14. public void setName(String name) { 
  15. this.name = name; 
  16.     } 
  17. public Integer getAge() { 
  18. return age; 
  19.     } 
  20. public void setAge(Integer age) { 
  21. this.age = age; 
  22.     } 
  23. public User() { 
  24.     } 

4:创建dao接口、可以说是Mapper接口:UserMapper

[java]view plaincopyprint?

  1. package com.forum.dao; 
  2. import com.forum.po.User; 
  3. public interface UserMapper { 
  4. public User findById(String Id); 

5:创建dao的实现,不同于hibernarte的此处的实现为一个xml文件,也就是userMapper.xml

[html]view plaincopyprint?

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC  
  3.     "-//mybatis.org//DTD Mapper 3.0//EN" 
  4.     "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <!--这块等于dao接口的实现  namespace必须和接口的类路径一样-->
  6. <mapper namespace="com.forum.dao.UserMapper">
  7. <!-- findById必须和接口中的方法名一样  返回一个User  就是刚才的别名  如果不弄别名要连类路径一起写 麻烦-->
  8. <select id="findById" parameterType="HashMap" resultType="User">
  9.         select 
  10.         * from butone.student where id=#{id} 
  11. </select>
  12. </mapper>


6:测试类,MyBatisTest

[java]view plaincopyprint?

  1. package com.forum.test; 
  2. import java.io.IOException; 
  3. import org.apache.ibatis.io.Resources; 
  4. import org.apache.ibatis.session.SqlSession; 
  5. import org.apache.ibatis.session.SqlSessionFactory; 
  6. import org.apache.ibatis.session.SqlSessionFactoryBuilder; 
  7. import com.forum.dao.UserMapper; 
  8. import com.forum.po.User; 
  9. /**
  10. * myBatis数据库连接测试
  11. *
  12. * @author db2admin
  13. *
  14. */
  15. public class MyBatisTest { 
  16. /**
  17.      * 获得MyBatis SqlSessionFactory 
  18.      * SqlSessionFactory负责创建SqlSession,一旦创建成功,就可以用SqlSession实例来执行映射语句,commit,rollback,close等方法。
  19.      * @return
  20.      */
  21. private static SqlSessionFactory getSessionFactory() { 
  22.         SqlSessionFactory sessionFactory = null; 
  23.         String resource = "configuration.xml"; 
  24. try { 
  25.             sessionFactory = new SqlSessionFactoryBuilder().build(Resources 
  26.                     .getResourceAsReader(resource)); 
  27.         } catch (IOException e) { 
  28. // TODO Auto-generated catch block
  29.             e.printStackTrace(); 
  30.         } 
  31. return sessionFactory; 
  32.     } 
  33. public static void main(String[] args) { 
  34.         SqlSession sqlSession = getSessionFactory().openSession(); 
  35.         UserMapper userMapper = sqlSession.getMapper(UserMapper.class); 
  36.         User user = userMapper.findById("1"); 
  37.         System.out.println(user.getName()); 
  38.     } 

原文地址;http://blog.csdn.net/huzheaccp/article/details/7399124

 

MyBatis之作用域和生命周期

 

本文转自:MyBatis3用户指南中文版、入门五,关于这个文档我上传的资源里边有,大家可以去下载!

http://download.csdn.net/detail/huzheaccp/4177008

http://download.csdn.net/detail/huzheaccp/4177008

http://download.csdn.net/detail/huzheaccp/4177008

对于这些概念性的东西,总怕自己说不清楚,害怕害了看了我博客的人,所以抄书,哈哈...

理解作用域和生命周期类非常重要,如果使用不当,会造成各种各样的问题。

1.SqlSessionFactoryBuildeSqlSessionFactoryBuilder

[plain]view plaincopyprint?

  1. 这个类可以被初始、使用和丢弃,如果你已经创建好了一个SqlSessionFactory 后就不用再保留它。因此, 
  2. SqlSessionFactoryBuilder 的最好作用域是方法体内, 比如说定义一个方法变量。你可以重复使用 
  3. SqlSessionFactoryBuilder 生成多个SqlSessionFactory 实例,但是最好不要强行保留,因为XML 的解析资 
  4. 源要用来做其它更重要的事。 

2.SqlSessionFactory

[plain]view plaincopyprint?

  1. 一旦创建,SqlSessionFactory 就会在整个应用过程中始终存在。所以没有理由去销毁和再创建它,一个 
  2. 应用运行中也不建议多次创建SqlSessionFactory。如果真的那样做,会显得很拙劣。因此SqlSessionFactory 
  3. 最好的作用域是Application。可以有多种方法实现。最简单的方法是单例模式或者是静态单例模式。然 
  4. 而这既不是广泛赞成和好用的。反而,使用Google Guice 或Spring 来进行依赖反射会更好。这些框架允 
  5. 许你生成管理器来管理SqlSessionFactory 的单例生命周期。 

3.SqlSession

[plain]view plaincopyprint?

  1. 每个线程都有自己的SqlSession 实例,SqlSession 实例是不能被共享,也是不是线程安全的。因此最好 
  2. 使用Request 作用域或者方法体作用域。不要使用类的静态变量来引用一个SqlSession 实例,甚至不要 
  3. 使用类的一个实例变更来引用。永远不要在一个被管理域中引用SqlSession ,比如说在Servlet 中的 
  4. HttpSession 中。如果你正在使用WEB 框架,应该让SqlSession 跟随HTTP 请求的相似作用域。也就是 
  5. 说,在收到一个HTTP 请求过后,打开SqlSession,等返回一个回应以后,立马关掉这个SqlSession。关 
  6. 闭SqlSession 是非常重要的。你必须要确保SqlSession 在finally 方法体中正常关闭。可以使用下面的标 
  7. 准方式来关闭: 
  8. SqlSession session = sqlSessionFactory.openSession(); 
  9. try { 
  10. // do work 
  11. } finally { 
  12. session.close(); 

使用这种模式来贯穿你的所有代码,以确保所有数据库资源都被完全关闭。[这是假定不是使用你自己的
数据库连接,而是使用MyBatis 来管理你的数据库连接资源]

4.Mapper实例

[plain]view plaincopyprint?

  1. Mapper 是一种你创建的用于绑定映射语句的接口。Mapper 接口的实例是用SqlSession 来获得的。同样, 
  2. 从技术上来说,最广泛的Mapper 实例作用域像SqlSession 一样,使用请求作用域。确切地说,在方法 
  3. 被调用的时候调用Mapper 实例,然后使用后,就自动销毁掉。不需要使用明确的注销。当一个请求执 
  4. 行正确无误的时候,像SqlSession 一样,你可以轻而易举地操控这一切。保持简单性,保持Mapper 在 
  5. 方法体作用域内。下面演示了如果来操作: 
  6. SqlSession session = sqlSessionFactory.openSession(); 
  7. try { 
  8. BlogMapper mapper = session.getMapper(BlogMapper.class); 
  9. // do work 
  10. } finally { 
  11. session.close(); 

原文地址:http://blog.csdn.net/huzheaccp/article/details/7399286

MyBatis入门学习的更多相关文章

  1. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

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

  2. MyBatis入门学习(二)

    在MyBatis入门学习(一)中我们完成了对MyBatis简要的介绍以及简单的入门小项目测试,主要完成对一个用户信息的查询.这一节我们主要来简要的介绍MyBatis框架的增删改查操作,加深对该框架的了 ...

  3. MyBatis入门学习(一)

    一.MyBatis入门简要介绍(百科) MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.MyB ...

  4. 记录21.08.04 — mybatis入门学习

    mybatis入门 mybatis简介 MyBatis 是一款优秀的持久层框架,它支持自定义 SQL.存储过程以及高级映射.MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工 ...

  5. MyBatis入门学习教程-MyBatis快速入门

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

  6. mybatis入门学习记录(一)

    过硬的技术本领,可以给我们保驾护航,飞得更高.今天开始呢.我们就一起来探讨使用mybatis的好处. 首先我们一起来先看看原生的JDBC对于数据库的操作,然后总结其中的利弊,为学习mybatis奠定基 ...

  7. MyBatis入门学习教程-Mybatis3.x与Spring4.x整合

    一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype:create -DgroupId=me.gacl -DartifactId=spring4-myba ...

  8. MyBatis入门学习教程-MyBatis缓存

    一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了 package me.gacl.test; 2 import me.gacl.domain.User; import ...

  9. MyBatis入门学习教程-调用存储过程

    一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 create table p_user( id int primary key auto_incr ...

随机推荐

  1. hdu 2072

    Ps:啊啊啊啊啊啊!WA了N次!真的是N次......终于做出来了...想哭的心情都有了... 这道题要考虑前面有N个空格,中间有N个空格,后面也有N个空格....然后就是输入空格.... 贴上代码: ...

  2. http://www.tracefact.net/CSharp-Programming/Delegates-and-Events-in-CSharp.aspx

    http://www.tracefact.net/CSharp-Programming/Delegates-and-Events-in-CSharp.aspx

  3. Interview----用最快的方法计算 Fibonacci 数

    输入 n, 用最快的方法求该 Fibocacci 数列的第 n 项. 方法1: 递归,非常慢 方法2: 迭代,因此计算 f[1] , f[2], f[3] ,,,, 复杂度 O(N) 方法3: 采用以 ...

  4. BZOJ 2292 永远挑战

    最短路. #include<iostream> #include<cstdio> #include<cstring> #include<algorithm&g ...

  5. session 和 cookie 的区别和联系

    二者的定义: 当你在浏览网站的时候,WEB 服务器会先送一小小资料放在你的计算机上,Cookie 会帮你在网站上所打的文字或是一些选择,都纪录下来.当下次你再光临同一个网站,WEB 服务器会先看看有没 ...

  6. css制作三角形

    #triangle-up { width: 0; height: 0; border-left: 50px solid transparent; border-right: 50px solid tr ...

  7. c++学习笔记4:如何写好注释

    1.单行注释一般放在语句的上方: // cout and endl live in the iostream library std::cout << "Hello world! ...

  8. 《more effective c++》条款26 限制类对象的个数

    问题: 如何限制类对象的个数?比如1个,10个等等. 方法(1): 将类的构造函数定义为private,那么就无法实例化这个类了.但是如何创建1个对象出来?方法有2种: 1.声明一个友元函数,那么在友 ...

  9. Xcode编译异常和警告汇总(持续更新中)

    1.Method definition for 'xxx' not found xxx的方法没有实现 出现原因.h声明了xxx方法但是.m没有实现xxx方法 解决方法:在类的.m文件实现xxx方法   ...

  10. C#堆栈讲解

    1:栈就是堆栈,因为堆和堆栈这样说太拗口了,搞得像绕口令,所以有些时候就把堆栈简称为栈.堆和栈,你看这又多舒服.但无论什么时候,堆栈都不等于堆和栈,必须说,堆和栈或者堆和堆栈. 2:值类型变量和引用类 ...