Mybatis学习(壹)
一、Mybatis的引言
1、Mybatis框架概念:是数据库持久层的框架,对数据库的访问和操作。Mybatis对JDBC的封装,Mybatis替换JDBC开发,解决DAO中的通用问题。
2、JDBC开发DAO的缺点:

3、Mybatis的优点
1)自动的进行ORM,减少冗余代码
2)有缓存机制,提高软件的效率
3)Mybatis提供动态sql,减少DAO方法的开发(select)
4、Mybatis的开发原理

二、第一Mybatis程序
1、搭建Mybatis环境
a、导入jar包
Mybatis的核心jar包:mybatis-3.2.2.jar
数据的驱动jar:ojdbc5.jar
做日志记录:log4j.jar
commons-logging-1.1.3.jar
b、引入配置文件
mybatis-config.xml:配置Mybatis运行环境
放置位置:随意,放在src目录
mapper文件:DAO实现的方法,通过mapper创建DAO
放置位置:随意,放在dao包下
log4j.properties:【可选】打印日志
放置位置:src目录
c、初始化参数配置
在mybatis-config.xml中配置mybatis的运行环境

2、Mybatis的核心API介绍
1)Resources:获得mybatis-config.xml配置文件
2)SqlSession:
作用一:获得DAO的实现类
作用二:内部封装一个Connection,一个SqlSession和一个Connection对象一一对应
作用三:可以事务控制
commit();rollback();
3)SqlSessionFactory:创建SqlSession,重量级
3、Mybatis替换JDBC开发DAO的步骤
1)建表
2)实体
3)DAO 的接口
4)Mybatis实现DAO的接口

5)注册mapper文件

6)测试

三、单表的基本操作(一个参数)
1、查询所有

模糊查询

2、删除
注意:Mybatis做数据库的DML操作必须进行事务控制(Mybatis的事务默认是回滚)
sqlSession.commit();/sqlSession.rollback()

3、修改

4、添加
使用序列:
insert into t_user values(seq_user.nextval,'yyy','999999')


mysql数据库没有序列:
<insert id="insert" parameterType="com.ibs.api.perf.bean.PerfAmmeter" useGeneratedKeys="true" keyProperty="id">
四、MybatisUtil的封装(参考MybatisUtil.java)
1、作用:提高代码的服用,提高程序的维护
2、service:SqlSession---DAO+事务控制
dao:调用DAO的方法完成业务
事务控制:SqlSession
获得sqlSession的方法
public static SqlSession getSqlSession(){}
3、MybatisUtil工具类封装的原则
1)读取配置文件的操作放在静态代码块中
2)sqlSession和Connection一一对应,对SqlSession进行线程绑定
3)SqlSessionFactory是一个重量级的,只需要创建一次,把SqlSessionFactory定义为静态成员变量
4、封装关闭SQLSession的方法:把关闭的SQLSession从线程局部变量中移除掉
public static void closeSession(){}
Mybatis学习(壹)的更多相关文章
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)
本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...
- MyBatis学习总结(八)——Mybatis3.x与Spring4.x整合(转载)
孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(八)--Mybatis3.x与Spring4.x整合 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: m ...
- MyBatis学习总结(七)——Mybatis缓存(转载)
孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(七)--Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的 ...
- (原创)mybatis学习二,spring和mybatis的融合
mybatis学习一夯实基础 上文介绍了mybatis的相关知识,这一节主要来介绍mybaits和spring的融合 一,环境搭建 1,jar包下载,下载路径为jar包 2,将包导入到java工程中 ...
- (原创)mybatis学习一,夯实基础
一,what?(是什么) MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可 ...
- MyBatis学习--简单的增删改查
jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...
- 【Todo】Mybatis学习-偏理论
之前写过好几篇Mybatis相关的文章: http://www.cnblogs.com/charlesblc/p/5906431.html <SSM(SpringMVC+Spring+Myba ...
- MyBatis学习系列三——结合Spring
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring MyBatis在项目中应用一般都要结合Spring,这一章主要把MyBat ...
- MyBatis学习系列二——增删改查
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...
随机推荐
- 安卓开发之json解析
1.从网页获取json返回字符串 public class ReadNet extends AsyncTask<URL, Integer, String> { @Override ...
- Git笔记 整理2
补充: 1,如何只克隆git仓库中的一个分支? git clone -b <branch> <remote_repo> eg: git clone -b vivien_dev ...
- 函数式编程之block
语法: 注意: 1,在代码块中可以使用和改变全局变量 2,而局部变量可以使用,但是不能改变. 怎么在代码块中改变局部变量呢?在局部变量前面加上关键字:__block 参考: Objective-C语法 ...
- php获取汉字的拼音 拼音首字母
/***获取汉字的拼音*/function pinyin($s, $isfirst = false) { static $pinyins; $s = trim($s); $len = strlen($ ...
- dup2()函数的使用,
#define STR "xiamanman\n"#define STR_LEN 10#define STDOUT 1 #include <stdio.h>#inclu ...
- Xcode:Foundation框架找不到,或者是自动提示出现问题
问题描述:Foundation框架找不到,或者是自动提示出现问题 之前的操作:手贱,不少心把编译器里面的源码改了 处理办法:清理缓存 缓存位置:点击桌面后,选择系统菜单栏:前往—电脑—硬盘—用户—ap ...
- CSS笔记(十四)CSS3之动画
参考:http://www.w3school.com.cn/css3/css3_animation.asp 通过 CSS3,我们能够创建动画,这可以在许多网页中取代动画图片.Flash 动画以及 Ja ...
- Java中的内省
为什么要学内省? •开发框架时,经常需要使用java对象的属性来封装程序的数据,每次都使用反射技术完成此类操作过于麻烦,所以sun公司开发了一套API,专门用于操作java对象的属性. 什么是Ja ...
- 16位的MD5加密和32位MD5加密的区别
16位的MD5加密和32位MD5加密的区别 MD5加密后所得到的通常是32位的编码,而在不少地方会用到16位的编码它们有什么区别呢?16位加密就是从32位MD5散列中把中间16位提取出来!其实破解16 ...
- spring事务知识
事务的传播行为? 在Spring 的事务中, _可以通过 propagation 来定义事务的传播行为_: PROPAGATION_required:如果当前没有事务,就新建一个事务,如果已经存在一个 ...