MyBatis之Hello world(Mybatis入门)
MyBatis中文网,超详细的:http://www.mybatis.org/mybatis-3/zh/index.html
MyBatis英文网:http://www.mybatis.org/mybatis-3/
MyBatis的Github:https://github.com/mybatis/mybatis-3
1:创建一个动态web工程
2:导入MyBatils必须的包
MyBatis的使用说明:
asm-3.3.1.jar 【字节码的包】
cglib-2.2.2.jar 【代理包】
commons-logging-1.1.1.jar 【日志包】
log4j-1.2.16.jar
mybatis-3.1.1.jar 【mybatis的核心包】
mysql-connector-java-5.1.40-bin.jar 【mysql的驱动包】
3:创建数据库和数据表,省略,创建实体类
package com.bie.mybatis01;
/**
* @author BieHongLi
* @version 创建时间:2017年4月11日 下午2:47:03
*
*/
public class User { private Integer id;//用户编号
private String name;//用户姓名
private int sal;//用户薪资 public Integer getId() {
System.out.println("测试配置文件,确实是调用了user.getId");
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
System.out.println("测试配置文件,确实是调用了user.getName");
return name;
}
public void setName(String name) {
this.name = name;
}
public int getSal() {
System.out.println("测试配置文件,确实是调用了user.getSal");
return sal;
}
public void setSal(int sal) {
this.sal = sal;
}
public User(Integer id, String name, int sal) {
super();
this.id = id;
this.name = name;
this.sal = sal;
} }
4:创建MyBatis的工具类:
package com.bie.utils; import java.io.IOException;
import java.io.Reader;
import java.sql.Connection; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; /**
* @author BieHongLi
* @version 创建时间:2017年4月11日 下午3:01:22
* 工具类
*/
public class MyBatisUtils { //定义私有静态当前线程泛型(SqlSession)对象
private static ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>();
//定义私有静态sqlSessionFactory
private static SqlSessionFactory sqlSessionFactory; //静态块,使用该类时,自动加载该静态块
//加载位于src目录下面的mybatis.cfg.xml配置文件
static{
try {
//读取配置文件mybatis.cfg.xml
Reader reader = Resources.getResourceAsReader("mybatis.cfg.xml");
sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
} catch (IOException e) {
e.printStackTrace();
throw new RuntimeException(e);
}
} //禁止外界通过new方法创建
private MyBatisUtils(){} //获取SqlSession
public static SqlSession getSqlSession(){
//从当前线程中获取SqlSession对象
SqlSession sqlSession = threadLocal.get();
//如果SqlSession对象为空
if(sqlSession == null){
//在SqlSessionFactory非空的情况下,获取SqlSession对象
sqlSession = sqlSessionFactory.openSession();
//将sqlSession对象与当前线程绑定在一起
threadLocal.set(sqlSession);
}
//返回sqlSession对象
return sqlSession;
} //关闭SqlSession与当前线程分开
public static void closeSqlSession(){
//从当前线程中获取SqlSession对象
SqlSession sqlSession = threadLocal.get();
//如果SqlSession对象非空
if(sqlSession != null){
//关闭SqlSession对象
sqlSession.close();
//分开当前线程与SqlSession对象的关系,目的是让GC尽早回收
threadLocal.remove();
}
} /*public static void main(String[] args) {
SqlSession sqlSession = MyBatisUtils.getSqlSession();
Connection con = sqlSession.getConnection();
if(con!=null){
System.out.println("连接成功");
}else{
System.out.println("连接失败");
} System.out.println(con!=null?"connection is ok":"connection is fail");
}*/ }
5:创建映射文件,放到其包中即可,如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"> <!-- MyBatis的映射配置文件
namespace:名称空间,必须唯一
-->
<!-- <mapper namespace="userNamespace"> -->
<mapper namespace="com.bie.mybatis01.User"> <!--
resultMap标签:映射实体与表
type属性:表示实体全路径名
id属性:为实体与表的映射取一个任意名称且唯一的名字
-->
<resultMap type="com.bie.mybatis01.User" id="userMap">
<!-- id标签映射主键
property属性:实体的属性名
column属性:表的字段名
-->
<id column="id" property="id"/> <!-- result标签非主键属性 -->
<result column="name" property="name"/>
<result column="sal" property="sal"/> </resultMap> <!--
insert标签:要书写insert这么一个sql语句
id属性:为insert这么一个sql语句取一个任意唯一的名字
-->
<insert id="insertId" parameterType="com.bie.mybatis01.User">
insert into user values(2,"张三",1234)
</insert> <insert id="insertId2" parameterType="com.bie.mybatis01.User">
<!--
可以这样理解,参数的设置,其实#{id} 就等价于#{user.getId()}
insert into user values(#{user.getId()},#{user.getName()},#{user.getSal()}); -->
insert into user values(#{id},#{name},#{sal})
</insert> </mapper>
6:创建配置文件,放到src目录下面,如mybatils.cfg.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"> <!-- 1:连接数据库的配置 -->
<configuration> <!-- 设置一个默认的连接环境信息 -->
<environments default="jdbc_developer"> <!-- 连接环境信息,取一个任意唯一的名字 -->
<environment id="jdbc_developer"> <!-- 2:MyBatis使用jdbc事务事务管理方式 -->
<transactionManager type="jdbc"></transactionManager> <!-- 3:MyBatis使用连接池方式来获取连接 -->
<dataSource type="pooled"> <!-- 4:配置与数据库交互的4哥必要属性 -->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql:///test"/>
<property name="username" value="root"/>
<property name="password" value="123456"/> </dataSource> </environment> </environments> <!-- 加载映射文件 -->
<mappers>
<mapper resource="com/bie/mybatis01/UserMapper.xml"/>
</mappers> </configuration>
7:开始写测试类UserDao进行测试
package com.bie.mybatis01; import org.apache.ibatis.session.SqlSession; import com.bie.utils.MyBatisUtil;
import com.bie.utils.MyBatisUtils; /**
* @author BieHongLi
* @version 创建时间:2017年4月11日 下午3:03:54
* dao层持久层:数据交互层
*/
public class UserDao { /***
* 用户添加的方法
* @param user
*/
public void insert(){
SqlSession sqlSession = null;
try {
//sqlSession = MyBatisUtils.getSqlSession();
sqlSession = MyBatisUtil.getSqlSession();
//事务开始(默认)
//读取UserMapper.xml映射文件中的SQL语句
int i = sqlSession.insert("userNamespace.insertId");
System.out.println("本次操作影响了" + i + "行"); //事务提交
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
//事务回滚
sqlSession.rollback();
}finally {
MyBatisUtils.closeSqlSession();
} } /***
* 插入带参的方法
* @param user
*/
public void insert2(User user){
SqlSession sqlSession = null;
try {
//第一首先链接数据库
sqlSession = MyBatisUtils.getSqlSession();
//默认打开事务
//读取UserMapper.xml映射文件的SQL语句
//第一个参数,命名空间.sql的id,d第二个参数是方法的参数user
sqlSession.insert("userNamespace.insertId2", user); //提交事务
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
//回滚事务
sqlSession.rollback();
}finally {
//关闭SqlSession
MyBatisUtils.closeSqlSession();
} } public void insert3(User user){
SqlSession sqlSession = null;
try {
//第一首先链接数据库
sqlSession = MyBatisUtils.getSqlSession();
//默认打开事务
//读取UserMapper.xml映射文件的SQL语句
//第一个参数,命名空间.sql的id,d第二个参数是方法的参数user
sqlSession.insert("com.bie.mybatis01.User.insertId2", user); //提交事务
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
//回滚事务
sqlSession.rollback();
}finally {
//关闭SqlSession
MyBatisUtils.closeSqlSession();
} } public static void main(String[] args) {
UserDao dao = new UserDao();
//dao.insert();
//dao.insert2(new User(3,"张三",1234));
dao.insert3(new User(4,"张三",1234)); } }
8:MyBatis的工作流
(a)通过Reader对象读取src目录下面的mybatis.xml配置文件(该配置文件的名称和未知可以任意)
Reader reader = Resources.getResourceAsReader("mybatis.cfg.xml");
(b)通过SqlSessionFactoryBuilder对象创建 SqlSessionFactory对象
sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
(c)从当前线程中获取SqlSession对象
SqlSession sqlSession = threadLocal.get();
(d)事务开始,在mybatis中默认
(e)通过SqlSession对象读取UserMapper.xml映射文件中的操作编号,从而读取sql语句
int i = sqlSession.insert("userNamespace.insertId");
(f)事务提交,必写
sqlSession.commit();
【注意:不要忘记事务回滚】
(g)关闭SqlSession对象,并且分开当前线程与SqlSession对象,让GC尽早回收
MyBatisUtils.closeSqlSession();
时间一分一秒的溜走,让自己做更有意义的事情,奋斗吧,小怪兽~~~
Time passes by, let yourself do more meaningful things, fight it, little monster ~ ~ ~ ~ ~ ~ ~ ~ ~!
MyBatis之Hello world(Mybatis入门)的更多相关文章
- MyBatis学习笔记(一)入门
首先给大家推荐几个网页: http://blog.csdn.net/isea533/article/category/2092001 没事看看 - MyBatis工具:www.mybatis.t ...
- 【转】MyBatis学习总结(一)——MyBatis快速入门
[转]MyBatis学习总结(一)——MyBatis快速入门 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC ...
- mybatis系列笔记(1)---mybatis入门
mybatis入门 MyBatis是什么? MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了goog ...
- MyBatis 学习总结 01 快速入门
本文测试源码下载地址: http://onl5wa4sd.bkt.clouddn.com/MyBatis0918.rar 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级 ...
- Mybatis系列(一):Mybatis入门
一.Mybatis是什么 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改 ...
- Mybatis系列(一)入门
Mybatis系列(一)入门 mybatis简介 MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结 ...
- 持久层之 MyBatis: 第一篇:快速入门
MyBatis入门到精通 JDBC回顾 1.1.认识MyBatis 1.1.使用IDEA创建maven工程 1.2.引入mysql依赖包 1.3.准备数据 1.4 使用JDBC手写MyBatis框架 ...
- Mybatis Dynamic Query 2.0 入门
简介 2.0 昨天打包好了,主要是整合了tk.mybatis.mapper 到项目中去,所以和1.x比起来主要多了一个通用mapper.因为作者主要是使用springboot 这里讲一下Springb ...
- springmvc+mybatis的增删改查入门
先到官网了解mybatis的语法:https://mybatis.org/mybatis-3/zh/sqlmap-xml.html 前端用了thymeleaf和vue.js,效果图和demo地址:ht ...
- 深入学习Mybatis框架(一)- 入门
1.什么是Mybatis? Mybatis是一个优秀持久层框架,提供了对数据库的一系列操作(增删改查).Mybatis可以避免重复的写JDBC代码,让我们以较少的代码实现对数据库的操作,从而提高开发效 ...
随机推荐
- Idea默认的全局设置,如Maven等
每次使用IDEA打开一个新的项目,maven都需要重新配置,非常不开心,所以需要有个默认全局配置,打破不开心 配置完就OK了 公众号 欢迎关注我的公众号“码上开发”,每天分享最新技术资讯.最优原创文章 ...
- XML文件详解以及解析
转自:https://blog.csdn.net/com_ma/article/details/73277535 一.xml基础详解: 1.概述: xml:即可扩展标记语言,xml是互联网数据传输的重 ...
- C++ 输入输出八进制、十进制、十六进制
默认进制 cin or cout在默认情况下按照十进制输入输出 八进制 要使输入为八进制数,首先切换至八进制输入 cin >> oct; //接下里就可以输入八进制数了 cin >& ...
- VUE2.0 饿了吗视频学习笔记(五):父子对象传递、显示图片
一.父子组件之间对象传递 1.app.Vue中的v-header 中加入 v-bind:seller="seller" template> <div id=" ...
- Objects源码解析
Objects类解析 JDK7新增Objects类介绍(以下程序以1.8来说明) 简介: JDK7里面新增的Objects类,本人学习HashMap源码偶遇此类,所以研究一下,本类将对象常用的 ...
- [NOIP2012提高]借教室 题解(二分答案+差分)
[NOIP2012提高&洛谷P1083]借教室 Description 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室 ...
- luogu P3198 [HNOI2008]遥远的行星
bzoj 洛谷 这题意是不是不太清楚 真正题意:求\[f_i=\sum_{j=1}^{\lfloor i*A \rfloor} \frac{M_i*M_j}{i-j}\] 似乎只能\(O(n*\lfl ...
- POJ3304 Segments 【线段直线相交】
题意: 给出n条线段两个端点的坐标,问所有线段投影到一条直线上,如果这些所有投影至少相交于一点就输出Yes!,否则输出No!. 思路: 计算几何.这道题要思考到两点: 1:把问题转化为是否存在一条直线 ...
- html 替换元素
参考博客:http://www.cnblogs.com/wkylin/archive/2011/05/12/2044328.html 可替换元素也是行内元素 替换元素是浏览器根据其标签的元素与属性来判 ...
- Database学习 - mysql 连接数据库 库操作
连接数据库 语法格式: mysql -h 服务器IP -P 端口号 -u用户名 -p密码 --prompt 命令提示符 --delimiter 指定分隔符 示例: mysql -h 127.0.0.1 ...