什么是MyBatis

在介绍MyBatis之前先简单了解几个概念:ORM,JPA。

ORM
ORM(Object-Relationship-Mapping):是对象关系映射的意思,它是一种思想,是指将数据库中的每一行数据用对象的形式表现出来。

JPA
JPA(Java-Persistence-API):是Java持久化接口的意思,它是JavaEE关于ORM思想的一套标准接口,仅仅是一套接口,不是具体的实现。

MyBatis概念
MyBatis是一个实现了JPA规范的用来连接数据库并对其进行增删改查操作的开源框架 (就和传统的JDBC一样,就是个连接数据库的东西),其实,它底层就是一个JDBC封装的组件。MyBatis的前身是Ibatis,Ibatis创建与2002年最初为Apache下面的一个开源项目,2010迁移到google code下面并改名为MyBatis。

MyBatis虽然实现了JPA但是它并不是一个完完全全的ORM组件,而是一个基于SQL开发的半ORM组件。

而Hibernate是一个完完全全的ORM组件,它是完全基于对象来操作数据库中的记录,并不和MyBatis一样是一个假把式。

MyBatis的优点
简单易学,容易上手(相比于Hibernate) ---- 基于SQL编程
消除了JDBC大量冗余的代码,不需要手动开关连接
很好的与各种数据库兼容(因为MyBatis使用JDBC来连接数据库,所以只要JDBC支持的数据库MyBatis都支持,而JDB提供了可扩展性,所以只要这个数据库有针对Java的jar包就可以就可以与MyBatis兼容),开发人员不需要考虑数据库的差异性。
提供了很多第三方插件(分页插件 / 逆向工程)
能够与Spring很好的集成
MyBatis开发环境的搭建
mybatis-3.4.1.jar
mysql-connector-java-5.1.24.jar
druid-1.1.5.jar(阿里的数据库连接池)
配置文件:

jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/test
jdbc.username=root
jdbc.password=123
1
2
3
4
UserMapper.xml(在该mapper文件里面编写statement句柄)

<?xml version="1.0" encoding="UTF-8" ?> SELECT USER_ID, USER_NAME, PASSWORD FROM USER 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 mybatis-cfg.xml(mybatis主配置文件) <?xml version="1.0" encoding="UTF-8" ?>
<!-- 加载jdbc配置文件 -->
<properties resource="jdbc.properties"></properties>

<!--
	开启驼峰命名,把符合数据库命名规范的字段(USER_NAME,单词之间带下划线)直接映射到
	与JAVA命名规范(驼峰命名法)相匹配的字段上,如果不开启这个选项,就需要在select语句
	的每个字段后面添加与实体类的属性名相同的别名以此来完成映射。
-->
<settings>
	<setting name="mapUnderscoreToCamelCase" value="true" />
</settings>

<!-- 为JAVA类型起别名 -->
<typeAliases>
	<!-- 为单个类起别名,type为全限定性类名,也可以用package为包下的类批量起别名 -->
	<typeAlias type="com.lyu.mybatiscsdn.entity.User" alias="user"/>
	<!-- 为整个包下的类批量起别名,别名为类名(大小写随意,例:User类的别名可以是uSeR,User,user...) -->
	<!-- <package name="com.lyu.mybatiscsdn.entity"/> -->
</typeAliases>

<!-- 配置环境 -->
<environments default="development">
	<environment id="development">
		<!-- 事务管理方式 -->
		<transactionManager type="JDBC" />
		<!-- 数据源采用连接池的方式 -->
		<dataSource type="POOLED">
			<!-- 用EL表达式的语法取jdbc.properties配置文件中的键对应的值 -->
			<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="UserMapper.xml"/>
</mappers>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 MyBatis的一个小Demo 实体类 package com.lyu.mybatiscsdn.entity;

import java.io.Serializable;

public class User implements Serializable {

private static final long serialVersionUID = -8433731482837977839L;

private Long userId;
private String userName;
private String password;

public Long getUserId() {
	return userId;
}
public void setUserId(Long userId) {
	this.userId = userId;
}
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;
}

}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
测试类
package com.lyu.mybatiscsdn.entity;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

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 org.junit.Before;
import org.junit.Test;

public class MyBatisTest {

SqlSessionFactory sqlSessionFactory;

@Before
public void init() throws IOException {
	// 配置文件的名称
	String configFile = "mybatis-cfg.xml";
	
	// 通过类加载器获取输入字节流
	InputStream is = Resources.getResourceAsStream(configFile);
	
	// 通过SqlSessionFactoryBuilder创建SqlSessionFactory
	sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
}

// 测试查询所用用户列表
@Test
public void testListUser() {
	// 创建SqlSession
	SqlSession sqlSession = sqlSessionFactory.openSession();
	
	// 声明sql句柄
	String listSql = "user.listUser";
	
	// 查询用户列表
	List<User> userList = sqlSession.selectList(listSql);
	
	for (User user : userList) {
		System.out.println("用户ID:" + user.getUserId());
		System.out.println("用户姓名:" + user.getUserName());
		System.out.println("用户密码:" + user.getPassword());
		System.out.println();
	}
	
	// 关闭sqlSession
	sqlSession.close();
}

}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
pom文件

4.0.0
com.lyu
mybatis-csdn
0.0.1-SNAPSHOT

<dependencies>
	<dependency>
	    <groupId>org.mybatis</groupId>
	    <artifactId>mybatis</artifactId>
	    <version>3.3.1</version>
	</dependency>
	<dependency>
	    <groupId>mysql</groupId>
	    <artifactId>mysql-connector-java</artifactId>
	    <version>5.1.24</version>
	</dependency>
	<dependency>
	    <groupId>com.alibaba</groupId>
	    <artifactId>druid</artifactId>
	    <version>1.1.5</version>
	</dependency>
	<dependency>
	    <groupId>junit</groupId>
	    <artifactId>junit</artifactId>
	    <version>4.12</version>
	    <scope>test</scope>
	</dependency>
</dependencies>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 项目的结构如下:

注意几点:session增删改操作后要commit提交,所有操作最后都要close关闭session

作者:曲健磊
来源:CSDN
原文:https://blog.csdn.net/a909301740/article/details/78698682
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值