栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Mybatis - Mapper代理开发目的与入门案例

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Mybatis - Mapper代理开发目的与入门案例

文章目录

Mapper代理开发

目的 Mapper代理方式入门案例

1.完成Mapper文件映射

创建包创建并放入模拟接口

创建目录编译映射文件成功 2.设置映射文件的namespace属性3.在Mapper接口中定义方法

更改mybatis-config.xml 4.模拟代理开发

demo02源码异常再次编译运行complete!!

Mapper代理开发 目的

解决原生方式中的硬编码简化后期执行SQL Mapper代理方式入门案例

    定义与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下

    设置SQL映射文件的namespace属性为Mapper接口全限定名

    在Mapper接口中定义方法,方法名就是SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致

    编码

1.完成Mapper文件映射

定义与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下

创建包

创建并放入模拟接口

创建目录

让Mapper接口与xml文件在同一目录下

    我们可以直接用鼠标拖动,但是显然不合适,文件比较乱,不方便管理我们在resources里新建目录,并映射

注意格式(要与mapper文件路径一致)

编译

把Tb_userMapper.xml文件移动到该目录下,并进行编译,这里我们使用maven插件进行编译

映射文件成功

2.设置映射文件的namespace属性

设置SQL映射文件的namespace属性为Mapper接口全限定名

3.在Mapper接口中定义方法

在Mapper接口中定义方法,方法名就是SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致

更改mybatis-config.xml

右键 - copy-path

4.模拟代理开发

复制demo02

demo02源码
package com.taotao;

import com.taotao.mapper.UserMapper;
import com.taotao.pojo.Tb_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;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;


public class MyBatisDemo02 {
    public static void main(String[] args) throws IOException {
        //1.加载mybatis的核心配置文件,获取 SqlSessionFactory
        String resource = "mybatis-config.xml"; //相对路径
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);


        //2.获取SqlSession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //3.执行sql
//        List users = sqlSession.selectList("test.selectAll");
        //3.1 获取userMapper接口的代理对象
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        List tb_users = userMapper.selectAll();
        System.out.println(tb_users);

        //4.释放资源
        sqlSession.close();
    }
}

异常

我换了root密码,所以重新改下root’@'localhost密码即可

再次编译运行

complete!!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/762801.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号