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

第一个mybatis程序(IDEA)

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

第一个mybatis程序(IDEA)

1. 第一个mybatis程序

思路:

–>搭建环境 (新建Maven项目)

–>在pom.xml中,导入Mybatis,mysql,Junit依赖

–>在resources文件夹中新建mybatis-config.xml文件

–>编写mybatis的工具类(MybatisUtils.java)

–>编写实体类(User.java)

–>编写Dao接口(UserDao.java)

–>编写UserMapper.xml配置文件

–>编写测试类,进行Junit测试

1.1 搭建环境

搭建数据库

//创建数据库
CREATE DATAbase `mybatis`;
use `mybatis`;
//创建表
CREATE TABLE `user`(
  `id` INT(20) not NULL PRIMARY KEY,
  `name` VARCHAR(100) DEFAULT NULL,
  `pwd` VARCHAR(50) DEFAULT NULL 
)ENGINE=INNODB default CHARSET=utf8;
//插入数据
insert into user values(1,'望穿先生','123456'),(1,'张三','123456')

新建项目

1.新建一个普通的maven项目

2.删除src目录

3.导入依赖

    
        
       
        
            mysql
            mysql-connector-java
            5.1.47
        
        
        
            org.mybatis
            mybatis
            3.5.9
        
        
        
            junit
            junit
            4.12
        
    
1.2 创建一个模块

编写mybatis的核心配置文件 (在resources文件夹中新建mybatis-config.xml文件)

(在xml中&等价于逻辑&符号)




    
        
            
            
                
                
                
                
            
        
    
    
        
    

编写mybatis的工具类(MybatisUtils.java)

//sqlsessionFactory
public class MybatisUtils {
    //提升sqlsession的作用域
    private static SqlSessionFactory sqlSessionFactory;

    //static代码块让他初始就去加载
    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();
    }
}
1.3 编写代码

实体类(User.java)

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(String name) {
        this.name = name;
    }

    public String getPwd() {
        return pwd;
    }

    public void setPwd(String pwd) {
        this.pwd = pwd;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + ''' +
                ", pwd='" + pwd + ''' +
                '}';
    }
}

Dao接口(UserDao.java)

//此处的UserDao等价于以后的mapper
public interface UserDao {
    List getUserList();
}

接口实现类由原来的JDBC中的UserImpl转变成为一个Mapper配置文件(UserMapper.xml)





    
    


1.4 测试

Junit测试

(测试尽量写在对应的test文件夹下,绿色的包中,并且包的结构尽量也要和上面尽可能对应)

public class UserDaoTest {
    @Test
    public void test() {
        //第一步,获取sqlsession对象
        SqlSession sqlSession = MybatisUtils.getsqlsession();
        //执行sql
        //方式1:通过getMapper()
        UserDao mapper = sqlSession.getMapper(UserDao.class);
        List userList = mapper.getUserList();
        for (User user : userList) {
            System.out.println(user);
        }
        //关闭sqlsession
        sqlSession.close();

    }
}

测试中可能遇到的问题:

    错误一:找不到mybatis配置文件java.io.IOException: Could not find resource org/mybatis/example/mybatis-config.xml

    解决方案

    在pom.xml中增加build

    
        
            
                src/main/resources
                
                    ***.xml
                
                false
            
            
                src/main/java
                
                    ***.xml
                
                false
            
        
    
    

    如果该方法仍然无法解决找不到配置文件的话,(1)再注意自己的mapper文件,在mybatis-config.xml配置文件中有没有注册;(2)查看自己的mybatis的工具类(MybatisUtils.java)中resources 的路径写的是否正确

    错误二: java.lang.ExceptionInInitializerError

    在mapper.xml文件中写了中文注释,导致报错

    解决方案:将头文件中的encoding="UTF-8" 改成UTF8

    重新运行后问题解决

    错误三:

    org.apache.ibatis.exceptions.PersistenceException:

    Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure数据库连接问题

    解决方案

    将mybatis-config.xml核心配置文件中useSSL=true改成false后问题解决

    
    

    错误四:

    org.apache.ibatis.binding.BindingException: Type interface com.lyl.dao.UserDao is not known to the MapperRegistry.

    UserMapper.xml文件中,namespace命名空间绑定问题

    
    

    解决方案

    查看自己的Dao/Mapper接口包的路径是否正确(路径要从java文件夹下开始写,com.xx.xx),修改正确后即可。

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

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

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