Mybatis框架学习小记(二)

mybatis编写步骤:

1. 创建maven依赖

 <!--导入依赖-->
 <dependencies>
     <!--mysql驱动-->
     <dependency>
 ​
         <groupId>mysql</groupId>
         <artifactId>mysql-connector-java</artifactId>
         <version>8.0.21</version>
     </dependency>
     <!--mybatis-->
     <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
     <dependency>
         <groupId>org.mybatis</groupId>
         <artifactId>mybatis</artifactId>
         <version>3.5.3</version>
     </dependency>
 ​
     <!--junit-->
     <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>3.8.1</version>
         <scope>test</scope>
     </dependency>
 ​
 </dependencies>

2. mybatis连接配置

 public class MybatisUtils {
     private static SqlSessionFactory sqlSessionFactory;
     static{
         try {
             //使用mybatis第一步:获取sqlSessionFactory对象
             String resource = "mybatis/example/mybatis-config.xml";
             InputStream inputStream = Resources.getResourceAsStream(resource);
             sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
         } catch (IOException e) {
 ​
         }
     }
     //SqlSession完全包含了面向数据库执行SQL命令所需的所有方法。
     public static SqlSession getSqlSession(){
         return sqlSessionFactory.openSessi2gaion();
 ​
     }
 }

3. 创建实体类

 //实体类
 public class User {
     private int id;
     private String name;
     private String password;
 ​
     public User() {
     }
 ​
     public User(int id, String name, String password) {
         this.id = id;
         this.name = name;
         this.password = password;
     }
 ​
     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 getPassword() {
         return password;
     }
 ​
     public void setPassword(String password) {
         this.password = password;
     }
 ​
     @Override
     public String toString() {
         return "User{" +
                 "id=" + id +
                 ", name='" + name + '\'' +
                 ", password='" + password + '\'' +
                 '}';
     }
 }

4. Dao接口

 public interface UserDao {
     List<User> getUserList();
 }

5.接口实现类

由原来的UserDaoImp转变为一个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">
 <!--namespace=绑定一个对应的Dao/Mapper接口-->
 <mapper namespace="com.dao.UserDao">
     <!--select查询语句-->
    <select id="getUserList" resultType="com.pojo.User">
        select * from mybatis.user
    </select>
 </mapper>

MapperRegistry是什么?

核心配置文件中注册mapper: pom.xml中

6. junit测试

 public class UserDaoTest {
     @Test
     public void test(){
         //第一步:获得SqlSession对象
         SqlSession sqlSession = MybatisUtils.getSqlSession();
         //第二步:执行SQL
         //方式一:getMapper
         UserDao userDao = sqlSession.getMapper(UserDao.class);
         List<User> userList = userDao.getUserList();
 ​
         for (User user: userList){
             System.out.println(user);
         }
         //关闭SqlSession
         sqlSession.close();
     }
 }

测试中可能遇到的问题:

  1. 配置文件没有中注册

  2. 绑定接口错误

  3. 方法名错误

  4. 返回类型错误

  5. maven导出资源问题  

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值