mybatis笔记01——初始配置

JavaEE三层架构:表现层 (负责与用户的交互,通常实现了用户界面)、业务逻辑层 (处理核心业务规则和逻辑,是应用程序的"心脏"。)、数据访问层(负责与数据源(如数据库)进行交互,包括数据的存储、检索和操作)。

mybatis环境配置(基于maven)

pom.xml文件必须导入以下依赖

XML 复制代码
    <dependencies>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.16</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>
    </dependencies>

resources文件夹下新建名为mybatis-config.xml的文件,并填写以下内容:

<?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">

在最上方还引入了一个叫做DTD(文档类型定义)的东西,它提前帮助我们规定了一些标签以及这些标签应该具有哪些属性,这些标签是Mybatis专属的配置标签,我们也必须要按照对应的方式来进行配置。

XML 复制代码
<?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">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql:///{数据库名称}?useSSL=false/dqlsearch"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>

    <mappers>
        <mapper resource="TestMapper.xml""/>
    </mappers>
</configuration>

接下来就是具体配置mybatis连接数据库的代码了

  • 环境(environments)里可以加多个environment,即连接不同的数据库,上面的default=" "里选择要用到的那个数据库。(可以连接不同的数据库来实现测试的效果
  • <transactionManager type="JDBC"/>:事务管理器我们这里直接使用JDBC即可
  • 数据源(dataSource)中配置就是驱动、连接地址(最后是要连接的数据库名称)、用户名和密码

之后在resources文件夹里面创建TestMapper.xml

在TestMapper.xml文件里写入

XML 复制代码
<?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="testMapper">

</mapper>

mapper继续看下面的说明

由于要获取student这张表里的学生对象数据,那么就在包里新建学生这个类

java 复制代码
@Data // 加上这个注解,就可以不写get set方法
public class student {
    int id;
    String name;
    int gander;
    ......
    //构造器和get set方法
}

之后在TestMapper.xml里配置sql映射

XML 复制代码
<?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="testMapper">
    <select id="SelectAllStudent" resultType="com.test.student">
        select * from studentscore;
    </select>
</mapper>

select标签里的id是该sql语句的名字,resultType是sql查询返回的类型

之后再在mybatis_config.xml里添加mappers标签(要在environments之后)

XML 复制代码
<typeAliases>  
    <package name="com.itheima.pojo"/>  
</typeAliases>
  • mapper.xml文件中
XML 复制代码
<configuration>
    ...
    <mappers>
        <mapper resource="TestMapper.xml"/>
    </mappers>
</configuration>

之后就可以在java文件里通过代码查询数据库了

java 复制代码
package com.test;

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;
import java.util.List;

public class mybatistest {
    public static void main(String[] args) throws IOException {
        String resource = "mybatis-config.xml";
        // 将mybatis-config.xml文件传入输入流
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession sqlSession = sqlSessionFactory.openSession(); // 获取到了数据库对象
        // 对数据库对象执行sql语句
        List<User> userList = sqlSession.selectList("test.selectAll");
        System.out.println(userList);
        // 关闭
        sqlSession.close();
    }
}
相关推荐
你干嘛?哎哟2 小时前
4月工作笔记
笔记
这是程序猿2 小时前
Spring Boot自动配置详解
java·大数据·前端
tom02183 小时前
软考中级《嵌入式系统设计师》全套备考资料(真题 + 教材 + 笔记)
笔记·嵌入式·软考·自学·电子技术·电子资料·变成
MY_TEUCK3 小时前
【Java 后端 | Nacos 注册中心】微服务治理原理、选型与注册发现实战
java·开发语言·微服务
小江的记录本4 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
问心无愧05134 小时前
ctf show web入门156
笔记
二宝哥4 小时前
离线安装maven
java·数据库·maven
咸甜适中4 小时前
rust语言学习笔记Trait(八)Iterator(迭代器)
笔记·学习·rust
日月云棠5 小时前
6 高级配置:Spring Boot整合、泛化调用与配置指南
java·后端
云烟成雨TD5 小时前
Spring AI Alibaba 1.x 系列【58】Spring AI Alibaba Builtin Nodes 模块介绍
java·人工智能·spring