Mybatis学习

1.简介

1.1什么是Mybatis?

请添加图片描述

1.2去哪获取?

Github
中文文档
maven仓库:

<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.6</version>
</dependency>

2.搭建环境

请添加图片描述

  1. 连接数据库(Database)
  2. 导入maven依赖(pom.xml)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <!--父工程-->
    <groupId>org.example</groupId>
    <artifactId>mybatis</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <modules>
        <module>mb01</module>
    </modules>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>
    <!--导入依赖-->
    <dependencies>
        <!--mysql驱动-->
        <dependency>
           <groupId>mysql</groupId>
           <artifactId>mysql-connector-java</artifactId>
           <version>5.1.46</version>
        </dependency>
        <!--Mybatis-->
        <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.6</version>
        </dependency>
        <!--junit-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
    </dependencies>

<!--在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>

</project>
  1. SqlSession(MybatisUtils)
package com.kuang.utiles;

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;
    public class MybatisUtils {
        static  SqlSessionFactory sqlSessionFactory;
        //这里使用static代码块的原因是想让代码一运行就创建一个SqlSessionFactory实例
        static{
            String resources = "mybatis-config.xml";
            InputStream inputStream = null;
            try {
                inputStream = Resources.getResourceAsStream(resources);
            } catch (IOException e) {
                e.printStackTrace();
            }
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        }
        //获取SqlSession的方法,每当需要执行SQL语句的时候都要调用这个方法
        public static SqlSession getSqlSession(){
            return sqlSessionFactory.openSession();
        }
}
  1. Mybatis核心配置文件(UserMapper.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">
<!--namespace=绑定一个Mapper/Dao接口-->
<mapper namespace="com.kuang.dao.UserMapper">
    <!--select查询语句-->
    <select id="getUserList" resultType="com.kuang.pojo.User">
        select * from mybatis.user;
    </select>
</mapper>
  1. 实体类(User)、接口(UserMapper)、Mapper文件(UserMapper.xml)
package com.kuang.pojo;

public class User {
        private int id;
        private String name;
        private String pwd;
        public User() {
        }
        public User(int id, String name, String pwd) {
            this.id = id;
            this.name = name;
            this.pwd = pwd;
        }
        public int getId() {
            return id;
        }
        public void setId(int id) {
            this.id = id;
        }
        public String getName() {
            return name;
        }
        public void setName() {
            this.name = name;
        }
        public String getPwd() {
            return pwd;
        }
        public void setPwd(String pwd) {
            this.pwd = pwd;
        }
}
package com.kuang.dao;

import com.kuang.pojo.User;
import java.util.List;

public interface UserMapper {
    public List<User> getUserList();
}
<?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=绑定一个Mapper/Dao接口-->
<mapper namespace="com.kuang.dao.UserMapper">
    <!--select查询语句-->
    <select id="getUserList" resultType="com.kuang.pojo.User">
        select * from mybatis.user;
    </select>
</mapper>
  1. 测试(UserMapperTest)
package com.kuang.dao;

import com.kuang.pojo.User;
import com.kuang.utils.MybatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import java.util.List;

public class UserMapperTest {


        @Test
        public void Test(){
            SqlSession sqlSession = MybatisUtils.getSqlSession();
            UserMapper mapper = sqlSession.getMapper(UserMapper.class);
            List<User> userList = mapper.getUserList();
            for (User user : userList) {
                System.out.print(user.getId());
                System.out.print(user.getName().toString());
                System.out.println(user.getPwd().toString());
            }
        }
}

总结:

  1. 连接数据库
  2. 导入jar包(maven依赖)
  3. SqlSession
  4. Mybatis核心配置文件
  5. 实体类、接口、Mapper文件(代替实现类)
  6. test

借鉴笔记

3.增删改查(掌握查)

请添加图片描述
请添加图片描述
请添加图片描述

4.配置(mybatis.config.xml)

请添加图片描述
注意标签顺序(有个表)

1.环境(environment)

请添加图片描述

2.properties

1.编写一个db.properties文件

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8
username=root
password=420138

2.在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>
     <!--引入外部配置文件-->
    <properties resource="db.properties"/>
    <!--注意标签顺序(有个表),properties在最前面,放在底下会报错-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com/xiezhr/Dao/UserMapper.xml"></mapper>
    </mappers>
</configuration>

${xxx} 表示的是:调用某个变量,该变量的名称就是{xxx}里面的"xxx"。

4. typeAliases(定义别名)

类型别名是为java类型这只一个短的名字。
意义在于用来减少过长类名的冗余

1.类配置别名
即自定义别名,使用typeAlias标签配置别名,type别名填写全限类定名,alias填写别名,将二者映射在一起。

<!--mybatis-config.xml-->
    <typeAliases>
        <typeAlias type="com.kuang.pojo.User" alias="user"/>
    </typeAliases>
<!--userMapper.xml里这样写即可-->
    <select id="userList" resultType="user">
        select * from user;
    </select>

2.包配置别名
也可以指定一个包名,MyBatis 会在包名下面搜索需要的Java Bean,比如:扫描实体类的包,它的默认别名就为这个类的类名,首字母小写!

<!--mybatis-config.xml-->
    <typeAliases>
        <package name="com.kuang.pojo"/>
    </typeAliases>
<!--userMapper.xml显示同上-->

在实体类比较少的时候,使用第一种方式。如果实体类十分多,建议使用第二种。
第一种可以DIY别名,第二种则·不行·,如果非要改,需要在实体类上增加注解

@Alias("user")
public class User {}

5.映射器——mappers

映射器是Mybatis中十分重要的,其完成的是注册*Mapper.xml,使得系统能够扫描到对应的xml文件。
三选一,建议1

<!-- 1.使用相对于类路径的资源引用 -->
<mappers>
<mapper resource="org/mybatis/builder/PostMapper.xml"/>
<!--<mapper resource="com/kuang/dao/UserMapper.xml"/>-->
</mappers>
<!--2.使用映射器接口实现类的完全限定类名需要配置文件名称和接口名称一致,并且位于同一目录下-->
<mappers>
<mapper class="org.mybatis.builder.AuthorMapper"/>
</mappers>
<!--3.将包内的映射器接口实现全部注册为映射器.但是需要配置文件名称和接口名称一致,并且位于同一目录下-->
<mappers>
<package name="org.mybatis.builder"/>
</mappers>

参考笔记

plugins插件,有数据库就能够自动生成mybatis代码,完成增删改查功能,偷懒用
请添加图片描述

5.生命周期和作用域

请添加图片描述
请添加图片描述
请添加图片描述

6.ResultMap结果集映射

结果集映射顾名思义就是对结果集进行一系列的处理,得到我们想要的数据。在SQL查询,尤其是复杂查询中,所得出来结果的列名在映射实体类中并不存在,导致在Java业务层中无法得到对应数据,这种情况就需要结果集映射来完成,简单来说就是为结果列名取别名,使得查询出来的结果类名能够对应上实体类上的属性名。

User.java

package com.kuang.pojo;

public class User {
        private int id;
        private String name;
        private String password;//pwd改名password
        public User() {
        }
    public User(int id, String name, String password) {
        this.id = id;
        this.name = name;
        this.password = password;
    }
//省略一些GetterSetter和toString

UserMapper.java文件

public interface UserMapper {
    //根据id查询用户
    User getUserById(int id);
}

UserMapper.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">
<!--namespace=绑定一个Mapper/Dao接口-->
<mapper namespace="com.kuang.dao.UserMapper">
    <!--结果集映射-->
    <resultMap id="UserMap" type="User">
        <!--colum数据库中的字段,property实体类中的属性-->
        <!--只用写需要更改的-->
        <result column="pwd" property="password" />
    </resultMap>

    <!--select查询语句-->
    <select id="getUserById" resultMap="UserMap">
        select * from mybatis.user where id = #{id};
    </select>
</mapper>

UserMapperTest.java

public class UserMapperTest {
        @Test
        public void Test(){
            SqlSession sqlSession = MybatisUtils.getSqlSession();
            UserMapper mapper = sqlSession.getMapper(UserMapper.class);
            User user = mapper.getUserById(3);
            System.out.println(user);

            sqlSession.close();
        }
}

结果集映射主要解决的是当前查询语句所查询出来的表的列名和属性名不一致的问题,并非是数据库列名和属性名不一致的问题,这点要注意
https://www.kuangstudy.com/bbs/1489949706024325122

7.注解

请添加图片描述
请添加图片描述

注解开发

mybatis使用注解开发可以不创建xml查询文件,但是弊端也很明显,对于较为复杂的SQL语句会显得接口变得十分臃肿,且无法完成复杂的SQL语句
直接把.UserMapper.xml删掉

//UserMapper.java
package com.kuang.dao;

import com.kuang.pojo.User;
import org.apache.ibatis.annotations.Select;

import java.util.List;

public interface UserMapper {
    @Select("select * from mybatis.user")
    List<User> getUserList();
}

https://www.kuangstudy.com/bbs/1499684790428209154

Mybatis Projecr
123:mb01
456:mb02
7:mb03

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值