对Mybatis的初步认识
1、认识Mybatis
MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。 MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索。 MyBatis 可以使用简单的XML 或注解用于配置和原始映射,将接口和 Java 的 POJO( Plain Old Java Objects,普通的Java 对象)映射成数据库中的记录.
1)MyBATIS 目前提供了三种语言实现的版本,包括:Java、.NET以及Ruby。(我主要学习java,就讲java的使用)
2)它提供的持久层框架包括SQL Maps和Data Access Objects(DAO)。
3)mybatis与hibernate的对比?
mybatis提供一种“半自动化”的ORM实现。
这里的“半自动化”,是相对Hibernate等提供了全面的数据库封装机制的“全自动化”ORM实现而言,“全自动”ORM实现了POJO和数据库表之间的映射,以及 SQL 的自动生成和执行。
而mybatis的着力点,则在于POJO与SQL之间的映射关系。
2、基于配置文件的CRUD 使用的mybatis的版本是3.1.1
User.java
public class User {
private Integer id;
private String username;
private String password;
public Integer getId() {
return id;
}
public void setId(Integer 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;
}
public User() {
super();
// TODO Auto-generated constructor stub
}
public User(Integer id, String username, String password) {
super();
this.id = id;
this.username = username;
this.password = password;
}
public User(String username, String password) {
super();
this.username = username;
this.password = password;
}
}
User.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.sram.pojo.User">
<!-- 插入语句 -->
<insert id="add" parameterType="com.sram.pojo.User">
INSERT INTO t_user(USERNAME,PASSWORD) VALUES(#{username},#{password});
</insert>
<!-- 更新语句 -->
<update id="update" parameterType="com.sram.pojo.User">
UPDATE t_user SET USERNAME=#{username},PASSWORD=#{password} WHERE ID=#{id};
</update>
<!-- 删除语句 -->
<delete id="delete" parameterType="int">
DELETE FROM t_user WHERE ID=#{id};
</delete>
<!-- 查询集合 -->
<select id="list" resultType="com.sram.pojo.User">
SELECT ID,USERNAME,PASSWORD FROM t_user;
</select>
<!-- 查询单个 -->
<select id="load" resultType="com.sram.pojo.User" parameterType="int">
SELECT ID,USERNAME,PASSWORD FROM t_user where ID=#{id};
</select>
</mapper>
Mybatis获取session的工具类MybatisUtil
public class MyBatiesUtil {
private static SqlSessionFactory factory;
//加载一次配置文件
static{
try {
InputStream in = Resources.getResourceAsStream("mybatis-config.xml");
factory = new SqlSessionFactoryBuilder().build(in);
} catch (IOException e) {
e.printStackTrace();
}
}
//得到sqlSession
public static SqlSession getSqlSession(){
return factory.openSession();
}
}
数据库的配置文件jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url = jdbc\:mysql\://localhost\:3306/mybatis?useUnicode\=true&characterEncoding\=utf-8
jdbc.username = root
jdbc.password = rrb
日志配置文件log4j.properties
#--------------------------------
#
log4j.rootLogger=INFO, stdout
#log4j.logger.test=info
#log4j.logger.org.apache.jasper = DEBUG
#log4j.logger.org.apache.catalina.startup.TldConfig = DEBUG
#log4j.logger.org.apache.catalina.session.ManagerBase = DEBUG
#log4j.logger.com.fiscal = DEBUG
#log4j.logger.com.system = DEBUG
log4j.logger.com.ibatis = DEBUG
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource = DEBUG
log4j.logger.com.ibatis.common.jdbc.ScriptRunner = DEBUG
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate = DEBUG
log4j.logger.java.sql.Connection = DEBUG
log4j.logger.java.sql.Statement = DEBUG
log4j.logger.java.sql.PreparedStatement = DEBUG
log4j.logger.java.sql.ResultSet = INFO
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
#log4j.appender.fileout=org.apache.log4j.RollingFileAppender
#log4j.appender.fileout.File=e:/log/ibatis.log
#log4j.appender.fileout.MaxFileSize=10000KB
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
#log4j.appender.stdout.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} :%m%n
#log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
#log4j.appender.fileout.layout.ConversionPattern=[%-5p]_%d{yyyy-MM-dd HH:mm:ss} :%m%n
#log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout
# log4j.logger.org=info
Mybatis配置文件mybatis-config.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="jdbc.properties"></properties>
<environments default="development">
<environment id="development" >
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<!-- 将mapper文件加入到配置文件中 -->
<mappers>
<mapper resource="com/sram/pojo/User.xml"/>
</mappers>
</configuration>
测试CRUD的测试类
public class UserTest {
//测试配置添加方法
@Test
public void add(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
User user = new User("张三","123");
session.insert(User.class.getName()+".add",user);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试配置更新方法
@Test
public void update(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
User user = new User(9,"李四","567");
session.update(User.class.getName()+".update",user);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试配置删除方法
@Test
public void delete(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
session.delete(User.class.getName()+".delete",10);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试配置查询集合方法
@Test
public void list(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
List<User> list = null;
try {
list = session.selectList(User.class.getName()+".list");
System.out.println(list);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试配置查询单个方法
@Test
public void load(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
User user = session.selectOne(User.class.getName()+".load",9);
System.out.println(user.getUsername());
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
}
3、基于注解的CRUD 使用的mybatis的版本是3.1.1
User.java
public class User {
private Integer id;
private String username;
private String password;
public Integer getId() {
return id;
}
public void setId(Integer 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;
}
public User() {
super();
// TODO Auto-generated constructor stub
}
public User(Integer id, String username, String password) {
super();
this.id = id;
this.username = username;
this.password = password;
}
public User(String username, String password) {
super();
this.username = username;
this.password = password;
}
}
UserMapper.java
public interface UserMapper {
@Insert("INSERT INTO t_user(USERNAME,PASSWORD) VALUES(#{username},#{password})")
public void addUser(User user);
@Update("UPDATE t_user SET USERNAME=#{username},PASSWORD=#{password} WHERE ID=#{id}")
public void update(User user);
@Delete("DELETE FROM t_user WHERE ID=#{id}")
public void delete(int id);
@Select("SELECT ID,USERNAME,PASSWORD FROM t_user")
public List<User> list();
@Select("SELECT ID,USERNAME,PASSWORD FROM t_user where ID=#{id}")
public User load(int id);
}
mybatis获取session的工具类 MybatisUtils.java
public class MyBatisUtil {
private static SqlSessionFactory factory;
//加载一次配置文件
static{
try {
InputStream in = Resources.getResourceAsStream("mybaties-config.xml");
factory = new SqlSessionFactoryBuilder().build(in);
} catch (IOException e) {
e.printStackTrace();
}
}
//得到sqlSession
public static SqlSession getSqlSession(){
return factory.openSession();
}
数据库的配置文件jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url = jdbc\:mysql\://localhost\:3306/mybatis?useUnicode\=true&characterEncoding\=utf-8
jdbc.username = root
jdbc.password = rrb
日志配置文件log4j.properties
#--------------------------------
#
log4j.rootLogger=INFO, stdout
#log4j.logger.test=info
#log4j.logger.org.apache.jasper = DEBUG
#log4j.logger.org.apache.catalina.startup.TldConfig = DEBUG
#log4j.logger.org.apache.catalina.session.ManagerBase = DEBUG
#log4j.logger.com.fiscal = DEBUG
#log4j.logger.com.system = DEBUG
log4j.logger.com.ibatis = DEBUG
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource = DEBUG
log4j.logger.com.ibatis.common.jdbc.ScriptRunner = DEBUG
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate = DEBUG
log4j.logger.java.sql.Connection = DEBUG
log4j.logger.java.sql.Statement = DEBUG
log4j.logger.java.sql.PreparedStatement = DEBUG
log4j.logger.java.sql.ResultSet = INFO
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
#log4j.appender.fileout=org.apache.log4j.RollingFileAppender
#log4j.appender.fileout.File=e:/log/ibatis.log
#log4j.appender.fileout.MaxFileSize=10000KB
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
#log4j.appender.stdout.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} :%m%n
#log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
#log4j.appender.fileout.layout.ConversionPattern=[%-5p]_%d{yyyy-MM-dd HH:mm:ss} :%m%n
#log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout
# log4j.logger.org=info
mybatis配置文件mybatis-confg.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="jdbc.properties"></properties>
<environments default="development">
<environment id="development" >
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<!-- 将mapper文件加入到配置文件中 -->
<mappers>
<mapper class="com.sram.mapper.UserMapper"/>
</mappers>
</configuration>
测试类
public class UserTest {
//测试注解添加方法
@Test
public void add(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
User user = new User("张三","123");
session.getMapper(UserMapper.class).addUser(user);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试注解更新方法
@Test
public void update(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
User user = new User(13,"李四","567");
session.getMapper(UserMapper.class).update(user);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试注解删除方法
@Test
public void delete(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
session.getMapper(UserMapper.class).delete(14);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试注解查询集合方法
@Test
public void list(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
List<User> list = null;
try {
list = session.getMapper(UserMapper.class).list();
System.out.println(list);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
//测试注解查询单个方法
@Test
public void load(){
//得到sqlSession
SqlSession session = MyBatiesUtil.getSqlSession();
try {
User user = session.getMapper(UserMapper.class).load(13);
System.out.println(user);
//事务提交
session.commit();
session.close();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}
}
}
对Mybatis的初步认识的更多相关文章
- java 持久框架mybatis的初步学习
什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索.MyBati ...
- Mybatis的初步使用
MyBatis 是当下最流行的持久层框架,也是ORM框架,本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google ...
- Mybatis学习-初步认知与使用
Mybatis是一款优秀的持久层框架.且支持定制化SQL,存储过程以及高级映射 Mybatis几乎免除了所有的JDBC代码以及设置参数和获取结果集的工作,它使用简单的XML或注解来配置原始类型.接口和 ...
- (一)Mybatis之初步接触
Maven的安装及环境配置 安装及配置只需按照以下三个链接的步骤走 撸帝的博客https://www.funtl.com/zh/maven/Maven-%E5%AE%89%E8%A3%85%E9%85 ...
- 初识 tk.mybatis.mapper
在博客园发表Mybatis Dynamic Query后,一位园友问我知不知道通用mapper,仔细去找了一下,还真的有啊,比较好的就是abel533写的tk.mybatis.mapper. 本次例子 ...
- 初识 tk.mybatis.mapper 通用mapper
在博客园发表Mybatis Dynamic Query后,一位园友问我知不知道通用mapper,仔细去找了一下,还真的有啊,比较好的就是abel533写的tk.mybatis.mapper. 本次例子 ...
- mybatis源码-解析配置文件(二)之解析的流程
目录 1. 简介 2. 配置文件解析流程分析 2.1 调用 2.2 解析的目的 2.3 XML 解析流程 2.3.1 build(parser) 2.3.2 new XMLConfigBuilder( ...
- mybatis源码-解析配置文件(一)之XML的DOM解析方式
目录 简介 Java 中 XML 文件解析 解析方式 DOM 解析 XML 新建 XML 文件 DOM 操作相关类 Java 读取 XML 文件 一起学 mybatis @ 简介 在之前的文章< ...
- SSM初步整合一
SSM(spring+springmvc+mybatis)初步整合一配置步骤: 步骤一.导入所需jar包 步骤二 .配置web.xml文件 <?xml version="1.0&quo ...
随机推荐
- [Winter Vacation] 语文实词虚词练习册答案
下载通道: [120个文言文实词小故事] [18个文言文虚词小故事] 120个文言文实词小故事 爱 楚人爱(宠爱)其子,虽爱(吝惜)钱财,于其子之求而无不应.其子成人,有陶氏之风独爱(喜爱)菊,众 ...
- 【sonar-block】Use try-with-resources or close this "BufferedInputStream" in a "finally" clause.
自己的理解: try-with-resources是JDK7的新语法结构,主要功能是自动关闭资源而不需要在finally里面手动close()关闭, 而且最重要的是,try块中的异常不会被close( ...
- redis在Linux上的部署和jedis简单使用
一.redis的安装 这里演示的版本是Redis4.0.6,Linux系统是CentOS6.7,Jdk1.7,Jedis2.8.1 这是官方文档介绍的安装方式 下载,解压,编译: $ wget htt ...
- 红黑树RBTree
#pragma onceenum colour //子节点的颜色{ RED, BLANK,};template<class K,class V>struct RBTree ...
- python 注释 与 windows 上用tab 自动补齐设置
python的注释 单行注释:用# 多行代码用:“”“ 中间为你要注释的解释 ”“” # 我是单行注释 我是一个#号 print("hello,word") "&quo ...
- Event(补交作业)
三种方法可以创建Eventhandler 1.
- mysql 快照读MVCC
mysql的读分快照读和当前读 快照读 是指写的同时,读不阻塞,达到并发的作用 这时候的读 是 记录的历史版本,存在于undo里,当然回滚时就的也是这个undo 当执行一条update语句时,记录本身 ...
- 2016级算法第一次练习赛-B.朴素的中位数
朴素的中位数 题目链接:https://buaacoding.cn/problem/846/index 分析 题意很简单,就是给定了两个从小到大排好序的数组,找出这两个数组合起来的数据中的中位数. 方 ...
- 微信智能机器人助手,基于hook技术,自动聊天机器人
下载地址: 链接:https://pan.baidu.com/s/1N5uQ3gaG2IZu7f6EGUmBxA 提取码:md7z 复制这段内容后打开百度网盘手机App,操作更方便哦 微信智能助手说明 ...
- 浅谈SLAM的回环检测技术
什么是回环检测? 在讲解回环检测前,我们先来了解下回环的概念.在视觉SLAM问题中,位姿的估计往往是一个递推的过程,即由上一帧位姿解算当前帧位姿,因此其中的误差便这样一帧一帧的传递下去,也就是我们所说 ...