mybatis学习总结系列来自孤傲苍狼博客:https://www.cnblogs.com/xdp-gacl/p/4261895.html
一、Mybatis介绍
MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。
二、mybatis快速入门
2.1、准备开发环境
1、创建测试项目,普通java项目或者是JavaWeb项目均可
2、添加相应的jar包
【mybatis】
mybatis-3.1.1.jar
【MYSQL驱动包】
mysql-connector-java-5.1.7-bin.jar
3、创建数据库和表,针对MySQL数据库
SQL脚本如下:
1 create database mybatis; 2 use mybatis; 3 CREATE TABLE users(id INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(20), age INT); 4 INSERT INTO users(NAME, age) VALUES('孤傲苍狼', 27); 5 INSERT INTO users(NAME, age) VALUES('白虎神皇', 27);
将SQL脚本在MySQL数据库中执行,完成创建数据库和表的操作
到此,前期的开发环境准备工作全部完成。
2.2、使用MyBatis查询表中的数据
1、添加Mybatis的配置文件conf.xml
在src目录下创建一个conf.xml文件
conf.xml文件中的内容如下:
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> 3 <configuration> 4 <environments default="development"> 5 <environment id="development"> 6 <transactionManager type="JDBC" /> 7 <!-- 配置数据库连接信息 --> 8 <dataSource type="POOLED"> 9 <property name="driver" value="com.mysql.jdbc.Driver" /> 10 <property name="url" value="jdbc:mysql://localhost:3306/mybatis" /> 11 <property name="username" value="root" /> 12 <property name="password" value="XDP" /> 13 </dataSource> 14 </environment> 15 </environments> 16 17 </configuration>
2、定义表所对应的实体类,
User类的代码如下:
1 package me.gacl.domain; 2 3 /** 4 * @author gacl 5 * users表所对应的实体类 6 */ 7 public class User { 8 9 //实体类的属性和表的字段名称一一对应 10 private int id; 11 private String name; 12 private int age; 13 14 public int getId() { 15 return id; 16 } 17 18 public void setId(int id) { 19 this.id = id; 20 } 21 22 public String getName() { 23 return name; 24 } 25 26 public void setName(String name) { 27 this.name = name; 28 } 29 30 public int getAge() { 31 return age; 32 } 33 34 public void setAge(int age) { 35 this.age = age; 36 } 37 38 @Override 39 public String toString() { 40 return "User [id=" + id + ", name=" + name + ", age=" + age + "]"; 41 } 42 }
3、定义操作users表的sql映射文件userMapper.xml
创建一个me.gacl.mapping包,专门用于存放sql映射文件,在包中创建一个userMapper.xml文件
userMapper.xml文件的内容如下:
1 <?xml version="1.0" encoding="UTF-8" ?> 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 3 <!-- 为这个mapper指定一个唯一的namespace,namespace的值习惯上设置成包名+sql映射文件名,这样就能够保证namespace的值是唯一的 4 例如namespace="me.gacl.mapping.userMapper"就是me.gacl.mapping(包名)+userMapper(userMapper.xml文件去除后缀) 5 --> 6 <mapper namespace="me.gacl.mapping.userMapper"> 7 <!-- 在select标签中编写查询的SQL语句, 设置select标签的id属性为getUser,id属性值必须是唯一的,不能够重复 8 使用parameterType属性指明查询时使用的参数类型,resultType属性指明查询返回的结果集类型 9 resultType="me.gacl.domain.User"就表示将查询结果封装成一个User类的对象返回 10 User类就是users表所对应的实体类 11 --> 12 <!-- 13 根据id查询得到一个user对象 14 --> 15 <select id="getUser" parameterType="int" 16 resultType="me.gacl.domain.User"> 17 select * from users where id=#{id} 18 </select> 19 </mapper>
4、在conf.xml文件中注册userMapper.xml文件
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> 3 <configuration> 4 <environments default="development"> 5 <environment id="development"> 6 <transactionManager type="JDBC" /> 7 <!-- 配置数据库连接信息 --> 8 <dataSource type="POOLED"> 9 <property name="driver" value="com.mysql.jdbc.Driver" /> 10 <property name="url" value="jdbc:mysql://localhost:3306/mybatis" /> 11 <property name="username" value="root" /> 12 <property name="password" value="XDP" /> 13 </dataSource> 14 </environment> 15 </environments> 16 17 <mappers> 18 <!-- 注册userMapper.xml文件, 19 userMapper.xml位于me.gacl.mapping这个包下,所以resource写成me/gacl/mapping/userMapper.xml--> 20 <mapper resource="me/gacl/mapping/userMapper.xml"/> 21 </mappers> 22 23 </configuration>
5、编写测试代码:执行定义的select语句
创建一个Test1类,编写如下的测试代码:
package me.gacl.test; import java.io.IOException; import java.io.InputStream; import java.io.Reader; import me.gacl.domain.User; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class Test1 { public static void main(String[] args) throws IOException { //mybatis的配置文件 String resource = "conf.xml"; //使用类加载器加载mybatis的配置文件(它也加载关联的映射文件) InputStream is = Test1.class.getClassLoader().getResourceAsStream(resource); //构建sqlSession的工厂 SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is); //使用MyBatis提供的Resources类加载mybatis的配置文件(它也加载关联的映射文件) //Reader reader = Resources.getResourceAsReader(resource); //构建sqlSession的工厂 //SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader); //创建能执行映射文件中sql的sqlSession SqlSession session = sessionFactory.openSession(); /** * 映射sql的标识字符串, * me.gacl.mapping.userMapper是userMapper.xml文件中mapper标签的namespace属性的值, * getUser是select标签的id属性值,通过select标签的id属性值就可以找到要执行的SQL */ String statement = "me.gacl.mapping.userMapper.getUser";//映射sql的标识字符串 //执行查询返回一个唯一user对象的sql User user = session.selectOne(statement, 1); System.out.println(user); } }
相关推荐
MyBatis是一个强大的Java持久层框架,它主要处理SQL查询、存储过程以及复杂的对象映射。这个框架的主要优点是它可以避免大量的JDBC代码手动编写,同时也简化了结果集的处理。下面我们将深入探讨MyBatis的基本概念和...
### MyBatis 3.0.3 用户指南关键知识点总结 #### 一、关于文档代码复制的注意事项 在阅读和使用本文档时,请注意代码示例的特殊字符问题。现代文字处理工具虽然使得文本更加美观易读,但也可能对代码示例造成破坏,...
在这个快速入门教程中,我们将逐步了解如何创建第一个 MyBatis 程序。 1. **资源目录结构**: 在 MyBatis 项目中,`resources` 目录是存放资源文件的地方,如配置文件、映射器(Mapper)XML 文件等。在 Maven 项目...
《Spring与MyBatis整合详解..."spring-mybatis-spring-3.0.1.zip"资源包提供了一个快速入门的平台,对于学习和理解这种整合方式具有很高的价值。希望这份资源能对广大开发者有所帮助,进一步推动Java技术的普及和应用。
3. **快速入门** 初始化MyBatis-Plus,需要在Spring Boot的配置文件中添加MyBatis-Plus的相关依赖,然后创建实体类、Mapper接口和对应的XML文件,最后通过BaseMapper接口实现基本的CRUD操作。 4. **Lambda查询** ...
总结,Spring与MyBatis的整合提供了强大的数据访问能力,而"spring-mybatis-spring-1.2.0.zip"资源包则为开发者提供了快速入门的平台。通过深入理解整合原理和实践操作,可以有效提升开发效率,更好地服务于实际项目...
这个项目提供了一个快速入门的模板,帮助开发者理解它们之间的集成机制。 【描述】中提到,这个项目实现了基本的数据操作功能,包括添加(Add)、删除(Delete)、修改(Update)和查询(Query)。当你将此压缩包...
"Mybatis总结.pptx"可能是对整个Mybatis学习过程的全面回顾,包括所有上述知识点的综合,也可能包含实际项目中的一些最佳实践。 至于".txt"文件,如"学习(五)用到的表.txt"、"学习(五、六)用到的表.txt"、"快速...
这个章节是对 MyBatis 入门阶段的总结,回顾了前面学习的主要内容,包括 MyBatis 的配置、SQL 映射文件的编写、Mapper 接口的创建以及基本的 CRUD 操作。 4. **14mybatis和hibernate的本质区别和应用场景.avi** ...
这个入门小例子是一个很好的起点,可以帮助初学者快速理解并掌握SpringBoot和Mybatis的使用。通过实践和学习,你可以进一步探索SpringBoot的其他特性,如自动配置、Actuator监控、健康检查等,以及Mybatis的高级特性...
总结起来,MyBatis作为一款优秀的持久层框架,它通过简化SQL操作、提供动态SQL支持和自动对象映射等功能,大大提升了开发效率,降低了开发难度。在SSM架构中,MyBatis与SpringMVC、Spring协同工作,共同构建了一个...
总结来说,这个"springboot+mybatis-plus+swagger2全注释入门demo"项目是一个极好的学习资源,它教你如何利用现代Java开发工具构建一个优雅、规范的RESTful API服务。通过实践这个项目,你不仅可以掌握SpringBoot、...
### MyBatis 学习知识点概述 #### 一、MyBatis 概述与特性 - **MyBatis**:一种支持普通SQL查询、存储过程以及高级映射的优秀持久层框架。它允许开发者直接编写SQL语句,并通过简单的XML或注解进行参数设置和结果...
这个"mybatis基础1.zip"压缩包包含了一系列的教学视频,旨在帮助初级或无经验的IT从业者快速掌握MyBatis的基本用法和核心概念。 1. **原生态JDBC编程中的问题总结** 在视频"02原生态jdbc编程中的问题总结.avi"中,...
### MyBatis 学习知识点概览 #### 第一章:介绍 - **1.1 整合动机** MyBatis-Spring 的诞生旨在为 Spring ...以上内容总结了 MyBatis 学习的核心知识点,从安装配置到实际应用,为初学者提供了一个全面的学习指南。
今天,我们将学习如何搭建 Struts2+Spring+MyBatis 环境。 一、准备安装文件 首先,我们需要准备以下几个文件: 1. Struts2:struts-2.3.3-all.gz 2. Spring:spring-framework-3.1.1.RELEASE-with-docs.zip 3. ...
- **半自动特性**:MyBatis提供了一种半自动化的ORM实现方式,即框架负责处理简单的字段映射,而复杂的SQL语句和逻辑仍需开发者手动编写。 - **优势**:灵活性更高,开发者可以根据具体需求调整SQL语句,更好地...
这个入门小demo是学习MyBatis的一个良好起点,通过它,我们可以快速理解MyBatis的基本操作和核心概念。 首先,让我们深入了解MyBatis的配置文件。在MyBatis中,主配置文件(通常命名为`mybatis-config.xml`)包含了...
MyBatis 是一款著名的持久层框架,它支持定制化 SQL、存储过程以及高级映射。...这个 "mybatis-demo.zip" 文件是学习 MyBatis 的一个很好的起点,它将帮助你快速掌握 MyBatis 的基本用法,为后续的开发打下坚实的基础。