什么是MyBatis ?

本文介绍了ORM和JPA的概念,接着详细讲解了MyBatis,这是一个实现了JPA规范的半ORM组件,提供简单易学、数据库兼容性好等优点。还涵盖了MyBatis开发环境的搭建步骤及一个基本的使用示例。
摘要由CSDN通过智能技术生成

在介绍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句柄)
<?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">
<!--
	namespace就是个命名空间,与struts2的namespace类似
	是为了避免与其他mapper.xml的句柄id发生重复
 -->
<mapper namespace="user">
	<!-- 
		查询所有用户列表的statement
		因为开启了驼峰命名,所以不需要在每个字段后面加别名就可以直接把符合规则的字段映射到对应实体类的属性上
		resultType为返回的类型名,因为在mybatis-cfg.xml中配置了别名,所以这里可以直接写user
	-->
	<select id="listUser" resultType="user">
		SELECT USER_ID, USER_NAME, PASSWORD FROM USER
	</select>
</mapper>
  • mybatis-cfg.xml(mybatis主配置文件)
<?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>

	<!-- 加载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" 
  • 42
    点赞
  • 162
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值