什么是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
  • UserMapper.xml(在该mapper文件里面编写statement句柄)



<mapper namespace="user">
	
	<select id="listUser" resultType="user">
		SELECT USER_ID, USER_NAME, PASSWORD FROM USER
	select>
mapper>
  • mybatis-cfg.xml(mybatis主配置文件)


<configuration>

	
	<properties resource="jdbc.properties">properties>
	
	
	<settings>
		<setting name="mapUnderscoreToCamelCase" value="true" />
	settings>
	
	
	<typeAliases>
		
		<typeAlias type="com.lyu.mybatiscsdn.entity.User" alias="user"/>
		
		
	typeAliases>
	
	
	<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>
	
	
	<mappers>
		
		<mapper resource="UserMapper.xml"/>
	mappers>
	
configuration>

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;
	}
	
}

  • 测试类
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();
	}
	
}

  • pom文件
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0modelVersion>
	<groupId>com.lyugroupId>
	<artifactId>mybatis-csdnartifactId>
	<version>0.0.1-SNAPSHOTversion>
	
	<dependencies>
		<dependency>
		    <groupId>org.mybatisgroupId>
		    <artifactId>mybatisartifactId>
		    <version>3.3.1version>
		dependency>
		<dependency>
		    <groupId>mysqlgroupId>
		    <artifactId>mysql-connector-javaartifactId>
		    <version>5.1.24version>
		dependency>
		<dependency>
		    <groupId>com.alibabagroupId>
		    <artifactId>druidartifactId>
		    <version>1.1.5version>
		dependency>
		<dependency>
		    <groupId>junitgroupId>
		    <artifactId>junitartifactId>
		    <version>4.12version>
		    <scope>testscope>
		dependency>
	dependencies>
	
project>

项目的结构如下:

什么是MyBatis ?_第1张图片

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

关注我的微信公众号,观看更多精彩内容:

你可能感兴趣的:(【mybatis】,初识MyBatis)