`

MyBatis学习总结(一)--快速入门

 
阅读更多

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学习总结——MyBatis快速入门.docx

    MyBatis是一个强大的Java持久层框架,它主要处理SQL查询、存储过程以及复杂的对象映射。这个框架的主要优点是它可以避免大量的JDBC代码手动编写,同时也简化了结果集的处理。下面我们将深入探讨MyBatis的基本概念和...

    MyBatis-3.0.3-User-Guide.pdf

    ### MyBatis 3.0.3 用户指南关键知识点总结 #### 一、关于文档代码复制的注意事项 在阅读和使用本文档时,请注意代码示例的特殊字符问题。现代文字处理工具虽然使得文本更加美观易读,但也可能对代码示例造成破坏,...

    Mybatis入门-第一个mybatis程序,快速入门

    在这个快速入门教程中,我们将逐步了解如何创建第一个 MyBatis 程序。 1. **资源目录结构**: 在 MyBatis 项目中,`resources` 目录是存放资源文件的地方,如配置文件、映射器(Mapper)XML 文件等。在 Maven 项目...

    spring-mybatis-spring-3.0.1.zip

    《Spring与MyBatis整合详解..."spring-mybatis-spring-3.0.1.zip"资源包提供了一个快速入门的平台,对于学习和理解这种整合方式具有很高的价值。希望这份资源能对广大开发者有所帮助,进一步推动Java技术的普及和应用。

    spring-mybatis-spring-1.2.0.zip

    总结,Spring与MyBatis的整合提供了强大的数据访问能力,而"spring-mybatis-spring-1.2.0.zip"资源包则为开发者提供了快速入门的平台。通过深入理解整合原理和实践操作,可以有效提升开发效率,更好地服务于实际项目...

    spring-boot-mybatis-mysql-demo

    这个项目提供了一个快速入门的模板,帮助开发者理解它们之间的集成机制。 【描述】中提到,这个项目实现了基本的数据操作功能,包括添加(Add)、删除(Delete)、修改(Update)和查询(Query)。当你将此压缩包...

    mybatis-plus学习项目笔记

    3. **快速入门** 初始化MyBatis-Plus,需要在Spring Boot的配置文件中添加MyBatis-Plus的相关依赖,然后创建实体类、Mapper接口和对应的XML文件,最后通过BaseMapper接口实现基本的CRUD操作。 4. **Lambda查询** ...

    Mybatis入门资源

    "Mybatis总结.pptx"可能是对整个Mybatis学习过程的全面回顾,包括所有上述知识点的综合,也可能包含实际项目中的一些最佳实践。 至于".txt"文件,如"学习(五)用到的表.txt"、"学习(五、六)用到的表.txt"、"快速...

    mybatis基础2.zip

    这个章节是对 MyBatis 入门阶段的总结,回顾了前面学习的主要内容,包括 MyBatis 的配置、SQL 映射文件的编写、Mapper 接口的创建以及基本的 CRUD 操作。 4. **14mybatis和hibernate的本质区别和应用场景.avi** ...

    SpringBoot Mybatis 入门 小例子

    这个入门小例子是一个很好的起点,可以帮助初学者快速理解并掌握SpringBoot和Mybatis的使用。通过实践和学习,你可以进一步探索SpringBoot的其他特性,如自动配置、Actuator监控、健康检查等,以及Mybatis的高级特性...

    学习Mybatis,系统带你入门Mybatis

    总结起来,MyBatis作为一款优秀的持久层框架,它通过简化SQL操作、提供动态SQL支持和自动对象映射等功能,大大提升了开发效率,降低了开发难度。在SSM架构中,MyBatis与SpringMVC、Spring协同工作,共同构建了一个...

    springboot+mybatis-plus+swagger2全注释入门demo,让你代码更优雅

    总结来说,这个"springboot+mybatis-plus+swagger2全注释入门demo"项目是一个极好的学习资源,它教你如何利用现代Java开发工具构建一个优雅、规范的RESTful API服务。通过实践这个项目,你不仅可以掌握SpringBoot、...

    mybatis学习文档资料

    ### MyBatis 学习知识点概述 #### 一、MyBatis 概述与特性 - **MyBatis**:一种支持普通SQL查询、存储过程以及高级映射的优秀持久层框架。它允许开发者直接编写SQL语句,并通过简单的XML或注解进行参数设置和结果...

    mybatis基础1.zip

    这个"mybatis基础1.zip"压缩包包含了一系列的教学视频,旨在帮助初级或无经验的IT从业者快速掌握MyBatis的基本用法和核心概念。 1. **原生态JDBC编程中的问题总结** 在视频"02原生态jdbc编程中的问题总结.avi"中,...

    mybatis学习

    ### MyBatis 学习知识点概览 #### 第一章:介绍 - **1.1 整合动机** MyBatis-Spring 的诞生旨在为 Spring ...以上内容总结了 MyBatis 学习的核心知识点,从安装配置到实际应用,为初学者提供了一个全面的学习指南。

    hibernate与MyBatis的区别

    - **半自动特性**:MyBatis提供了一种半自动化的ORM实现方式,即框架负责处理简单的字段映射,而复杂的SQL语句和逻辑仍需开发者手动编写。 - **优势**:灵活性更高,开发者可以根据具体需求调整SQL语句,更好地...

    mybatis入门小demo

    这个入门小demo是学习MyBatis的一个良好起点,通过它,我们可以快速理解MyBatis的基本操作和核心概念。 首先,让我们深入了解MyBatis的配置文件。在MyBatis中,主配置文件(通常命名为`mybatis-config.xml`)包含了...

    mybatis-demo.zip

    MyBatis 是一款著名的持久层框架,它支持定制化 SQL、存储过程以及高级映射。...这个 "mybatis-demo.zip" 文件是学习 MyBatis 的一个很好的起点,它将帮助你快速掌握 MyBatis 的基本用法,为后续的开发打下坚实的基础。

Global site tag (gtag.js) - Google Analytics