MyBatis入门学习
所需要jar包:mybatis-3.x.x.jar 、如果需要和spring整合,还需要加入相关的包
1:看项目目录 红颜色不要关心

2:按照步骤:
1:加入jar包
2:创建数据源(configuration.xml)创建数据库(此处省略)
[html]view plaincopyprint?
- <?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>
- <typeAliases>
- <!--给实体类起一个别名 user -->
- <typeAlias type="com.forum.po.User" alias="User" />
- </typeAliases>
- <!--数据源配置 这块用 BD2数据库 -->
- <environments default="development">
- <environment id="development">
- <transactionManager type="jdbc" />
- <dataSource type="POOLED">
- <property name="driver" value="com.ibm.db2.jcc.DB2Driver" />
- <property name="url" value="jdbc:db2://localhost:50000/forum" />
- <property name="username" value="DB2ADMIN" />
- <property name="password" value="admin" />
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <!--userMapper.xml装载进来 同等于把“dao”的实现装载进来 -->
- <mapper resource="myBatis/userMapper.xml" />
- </mappers>
- </configuration>
3:创建实体类USER
[java]view plaincopyprint?
- package com.forum.po;
- /**
- * 用户类
- *
- * @author db2admin
- *
- */
- public class User extends Entity {
- private String name;
- private Integer age;
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public Integer getAge() {
- return age;
- }
- public void setAge(Integer age) {
- this.age = age;
- }
- public User() {
- }
- }
4:创建dao接口、可以说是Mapper接口:UserMapper
[java]view plaincopyprint?
- package com.forum.dao;
- import com.forum.po.User;
- public interface UserMapper {
- public User findById(String Id);
- }
5:创建dao的实现,不同于hibernarte的此处的实现为一个xml文件,也就是userMapper.xml
[html]view plaincopyprint?
- <?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">
- <!--这块等于dao接口的实现 namespace必须和接口的类路径一样-->
- <mapper namespace="com.forum.dao.UserMapper">
- <!-- findById必须和接口中的方法名一样 返回一个User 就是刚才的别名 如果不弄别名要连类路径一起写 麻烦-->
- <select id="findById" parameterType="HashMap" resultType="User">
- select
- * from butone.student where id=#{id}
- </select>
- </mapper>
6:测试类,MyBatisTest
[java]view plaincopyprint?
- package com.forum.test;
- import java.io.IOException;
- 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.forum.dao.UserMapper;
- import com.forum.po.User;
- /**
- * myBatis数据库连接测试
- *
- * @author db2admin
- *
- */
- public class MyBatisTest {
- /**
- * 获得MyBatis SqlSessionFactory
- * SqlSessionFactory负责创建SqlSession,一旦创建成功,就可以用SqlSession实例来执行映射语句,commit,rollback,close等方法。
- * @return
- */
- private static SqlSessionFactory getSessionFactory() {
- SqlSessionFactory sessionFactory = null;
- String resource = "configuration.xml";
- try {
- sessionFactory = new SqlSessionFactoryBuilder().build(Resources
- .getResourceAsReader(resource));
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- return sessionFactory;
- }
- public static void main(String[] args) {
- SqlSession sqlSession = getSessionFactory().openSession();
- UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
- User user = userMapper.findById("1");
- System.out.println(user.getName());
- }
- }
原文地址;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?
- 这个类可以被初始、使用和丢弃,如果你已经创建好了一个SqlSessionFactory 后就不用再保留它。因此,
- SqlSessionFactoryBuilder 的最好作用域是方法体内, 比如说定义一个方法变量。你可以重复使用
- SqlSessionFactoryBuilder 生成多个SqlSessionFactory 实例,但是最好不要强行保留,因为XML 的解析资
- 源要用来做其它更重要的事。
2.SqlSessionFactory
[plain]view plaincopyprint?
- 一旦创建,SqlSessionFactory 就会在整个应用过程中始终存在。所以没有理由去销毁和再创建它,一个
- 应用运行中也不建议多次创建SqlSessionFactory。如果真的那样做,会显得很拙劣。因此SqlSessionFactory
- 最好的作用域是Application。可以有多种方法实现。最简单的方法是单例模式或者是静态单例模式。然
- 而这既不是广泛赞成和好用的。反而,使用Google Guice 或Spring 来进行依赖反射会更好。这些框架允
- 许你生成管理器来管理SqlSessionFactory 的单例生命周期。
3.SqlSession
[plain]view plaincopyprint?
- 每个线程都有自己的SqlSession 实例,SqlSession 实例是不能被共享,也是不是线程安全的。因此最好
- 使用Request 作用域或者方法体作用域。不要使用类的静态变量来引用一个SqlSession 实例,甚至不要
- 使用类的一个实例变更来引用。永远不要在一个被管理域中引用SqlSession ,比如说在Servlet 中的
- HttpSession 中。如果你正在使用WEB 框架,应该让SqlSession 跟随HTTP 请求的相似作用域。也就是
- 说,在收到一个HTTP 请求过后,打开SqlSession,等返回一个回应以后,立马关掉这个SqlSession。关
- 闭SqlSession 是非常重要的。你必须要确保SqlSession 在finally 方法体中正常关闭。可以使用下面的标
- 准方式来关闭:
- SqlSession session = sqlSessionFactory.openSession();
- try {
- // do work
- } finally {
- session.close();
使用这种模式来贯穿你的所有代码,以确保所有数据库资源都被完全关闭。[这是假定不是使用你自己的
数据库连接,而是使用MyBatis 来管理你的数据库连接资源]
4.Mapper实例
[plain]view plaincopyprint?
- Mapper 是一种你创建的用于绑定映射语句的接口。Mapper 接口的实例是用SqlSession 来获得的。同样,
- 从技术上来说,最广泛的Mapper 实例作用域像SqlSession 一样,使用请求作用域。确切地说,在方法
- 被调用的时候调用Mapper 实例,然后使用后,就自动销毁掉。不需要使用明确的注销。当一个请求执
- 行正确无误的时候,像SqlSession 一样,你可以轻而易举地操控这一切。保持简单性,保持Mapper 在
- 方法体作用域内。下面演示了如果来操作:
- SqlSession session = sqlSessionFactory.openSession();
- try {
- BlogMapper mapper = session.getMapper(BlogMapper.class);
- // do work
- } finally {
- session.close();
- }
原文地址:http://blog.csdn.net/huzheaccp/article/details/7399286
MyBatis入门学习的更多相关文章
- MyBatis入门学习教程-使用MyBatis对表执行CRUD操作
上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...
- MyBatis入门学习(二)
在MyBatis入门学习(一)中我们完成了对MyBatis简要的介绍以及简单的入门小项目测试,主要完成对一个用户信息的查询.这一节我们主要来简要的介绍MyBatis框架的增删改查操作,加深对该框架的了 ...
- MyBatis入门学习(一)
一.MyBatis入门简要介绍(百科) MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.MyB ...
- 记录21.08.04 — mybatis入门学习
mybatis入门 mybatis简介 MyBatis 是一款优秀的持久层框架,它支持自定义 SQL.存储过程以及高级映射.MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工 ...
- MyBatis入门学习教程-MyBatis快速入门
一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...
- mybatis入门学习记录(一)
过硬的技术本领,可以给我们保驾护航,飞得更高.今天开始呢.我们就一起来探讨使用mybatis的好处. 首先我们一起来先看看原生的JDBC对于数据库的操作,然后总结其中的利弊,为学习mybatis奠定基 ...
- MyBatis入门学习教程-Mybatis3.x与Spring4.x整合
一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype:create -DgroupId=me.gacl -DartifactId=spring4-myba ...
- MyBatis入门学习教程-MyBatis缓存
一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了 package me.gacl.test; 2 import me.gacl.domain.User; import ...
- MyBatis入门学习教程-调用存储过程
一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 create table p_user( id int primary key auto_incr ...
随机推荐
- javascript splice
//arrayObject.splice(index,howmany,element1,.....,elementX)//index 必需.规定从何处添加/删除元素.(0)//howmany 必需.规 ...
- os.system和os.popen
使用os.popen调用test.sh的情况: python调用Shell脚本,有两种方法:os.system(cmd)或os.popen(cmd),前者返回值是脚本的退出状态码,后者的返回值是脚本执 ...
- IOS(SystemConfiguration)框架中关于测试连接网络状态相关方法
1. 在SystemConfiguration.famework中提供和联网相关的function, 可用来检查网络连接状态. 2. SC(SystemConfiguration)框架中关于测试连接网 ...
- Spring反射机制
Spring是分层的Java SE/EE应用一站式的轻量级开源框架,以IoC(Inverse of Control)和AOP(Aspect Oriented Programming)为内核,提供了展现 ...
- Android AIDL使用详解
1.什么是aidl:aidl是 Android Interface definition language的缩写,一看就明白,它是一种android内部进程通信接口的描述语言,通过它我们可以定义进程间 ...
- 数据库基本----SQL语句大全
学会数据库是很实用D~~记录一些常用的sql语句...有入门有提高有见都没见过的...好全...收藏下...其实一般用的就是查询,插入,删除等语句而已....但学学存储过程是好事...以后数据方面的东 ...
- yii弹出层
Yii弹出层,包装了JQuery的JDialog,使用很方便.Yii组件功能太强大,强大到无法自拔 $this->beginWidget('zii.widgets.jui.CJuiDialog' ...
- dedecms 列表页调用自定义字段
在列表附加字段中添加自己定义的字段 如: lwulr调用:{dede:list addfields="lwurl" channelid="1"}[field:l ...
- 兼容性所有浏览器的透明CSS设置
兼容所有浏览器的透明CSS设置: .transparent_class { filter:alpha(opacity=50); -moz-opacity:0.5; -khtml-opacity: 0. ...
- Win7下安装双系统Centos,并修复Centos引导加载程序安装在U盘上的问题
1.使用U盘安装Centos时,磁盘分区划分要注意:系统(包含Win7)只能4个主分区,所以只能在删除一个主分区或者在扩展分区的空闲分区内建立目录. 2.Centos在安装步骤的最后,引导加载程序的选 ...