IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Mybatis简介及第一个简单demo搭建 -> 正文阅读

[Java知识库]Mybatis简介及第一个简单demo搭建

闲话

最近开始学习《计算机网络:自顶向下方法》,买的是一本实体书,就不方便上传博客了,所以打算抽空把工作中常用的框架复习一遍,巩固巩固

一、什么是Mybatis

1、官方文档:Mybatis官网

2、简介

  • MyBatis 是一款优秀的持久层框架(dao层,主要与数据库进行交互),它支持自定义 SQL、存储过程以及高级映射
  • MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作
  • MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java - Objects,普通老式 Java 对象)为数据库中的记录

数据持久化:就是将程序的数据在持久状态(数据库)和瞬时状态(内存)转化的过程

3、为什么使用mybatis:JDBC代码复杂,使用mybatis简化操作,自动化

4、优点:

  • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
  • 提供映射标签,支持对象与数据库的orm字段关系映射
  • 提供对象关系映射标签,支持对象关系组建维护
  • 提供xml标签,支持编写动态sql

5、关于#和$
#{}是预编译处理,${}是字符串替换

默认情况下,我们都会使用 #{}参数语法时,MyBatis 会创建PreparedStatement 参数占位符,并通过占位符安全地设置参数(就像使用 ? 一样,防止SQL注入)。 这样做更安全,更迅速,通常也是首选做法

不过有时你就是想直接在 SQL 语句中直接插入一个不转义的字符串。
比如 ORDER BY 子句,这时候你可以:

ORDER BY ${columnName}

这样,MyBatis 就不会修改或转义该字符串了

二、一个简单的项目搭建

1、依赖导入
我们创建一个maven项目,所以需要配置pom.xml文件

<dependencies>
	<!--MySQL驱动-->
	<dependency>
    	<groupId>org.mybatis</groupId>
    	<artifactId>mybatis</artifactId>
    	<version>3.5.6</version>
	</dependency>
	<!--Mybatis-->
	<dependency>
    	<groupId>mysql</groupId>
    	<artifactId>mysql-connector-java</artifactId>
    	<version>8.0.27</version>
	</dependency>
	<!--Junit-->
	<dependency>
    	<groupId>junit</groupId>
    	<artifactId>junit</artifactId>
    	<version>4.13.1</version>
    	<scope>test</scope>
	</dependency>
</dependencies>

2、代码编写

  • 首先编写一个Mybatis工具类,获取sqlSession,sqlSession完全包含了面向数据库执行sql命令所需要的方法
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 java.io.IOException;
import java.io.InputStream;

/**
 * Mybatis工具类
 */
public class MybatisUtils {

    private static SqlSessionFactory sqlSessionFactory;

    static {
        try {
            // 使用Mybatis第一步:获取sqlSession
            String resource = "mybatis-config.xml";
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    // 既然有了sqlSessionFactory,我们就可以得到sqlSession实例了
    // sqlSession完全包含了面向数据库执行sql命令所需要的方法
    public static SqlSession getSqlSession() {
        return sqlSessionFactory.openSession();
    }
}
  • 编写实体类
/**
 * 人员信息
 */
public class User {
    
    private String userId;

    private String name;

    private int age;

    private String sex;

    public User(String userId, String name, int age, String sex) {
        this.userId = userId;
        this.name = name;
        this.age = age;
        this.sex = sex;
    }

    public String getName() {
        return name;
    }

    public String getUserId() {
        return userId;
    }

    public void setUserId(String userId) {
        this.userId = userId;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "User{" 
            + "userId='" + userId + '\'' 
            + ", name='" + name + '\'' 
            + ", age=" + age 
            + ", sex='" + sex + '\'' 
            + '}';
    }
}
  • Dao接口
import com.decade.entity.User;

import java.util.List;

public interface UserDao {
    List<User> getUserInfo(String userName);
}
  • 接口实现类(由jdbc实现类变成了Mapper.xml配置文件)
    namespace绑定Mapper接口
<?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" >
<mapper namespace="com.decade.mapper.UserDao">

    <select id="getUserInfo" resultType="com.decade.entity.User">
        select * from t_decade_user;
    </select>
</mapper>
  • 然后我们需要配置核心配置文件mybatis-config.xml,连接本地的数据库
    注意:数据库连接url里,参数连接符需要用 &amp;
<?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>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <!--驱动配置,com.mysql.jdbc.driver -->
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>

    <!--每一个mapper.xml文件都需要在核心配置文件中注册-->
    <mappers>
        <mapper resource="com/decade/mapper/UserMapper.xml"/>
    </mappers>
</configuration>

但是,由于maven约定大于配置的原因,我们写的配置文件如果放在Java文件夹下,那么就可能会出现无法被导出或生效的问题,所以,我们需要在pom文件里进行如下配置

	<!--在build中配置resources,来防止我们资源导出失败的问题-->
    <build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>true</filtering>
            </resource>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>
  • 编写一个测试类进行测试
import com.decade.entity.User;
import com.decade.mapper.UserDao;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import com.decade.utils.MybatisUtils;

import java.util.List;

public class UserDaoTest {

   @Test
   public void test() {
       // 第一步:获取sqlSession对象
       SqlSession sqlSession = MybatisUtils.getSqlSession();

       try {
           // 一共两种方式进行查询
           UserDao userDao = sqlSession.getMapper(UserDao.class);
           List<User> userList = userDao.getUserInfo();

           List<User> userInfos = sqlSession.selectList("com.decade.mapper.UserDao.getUserInfo");

           // 循环输出查询到的user信息
           userList.forEach(System.out::println);
       } catch (Exception e) {
           e.printStackTrace();
       } finally {
           // 关闭sqlSession
           sqlSession.close();
       }
   }
}

运行测试类结果如下
在这里插入图片描述

如有错误,欢迎指正

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-12-26 22:00:25  更:2021-12-26 22:02:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 8:55:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码