zoukankan      html  css  js  c++  java
  • 3月24

    2.3 编写代码

    1610288565160

    • 实体类

    • Dao接口

      public interface UserDao {
         public List<User> getUserList();
      }
    • 接口实现类 (由原来的UserDaoImpl转变为一个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.kuang.dao.UserDao">
         <select id="getUserList" resultType="com.kuang.pojo.User">
        select * from USER
       </select>
      </mapper>
    • 测试

      注意点:

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

      MapperRegistry是什么?

      核心配置文件(MyBatis-config.xml)中注册mappers

      <!--此处为我的包的路径-->
      <!--MyBatis-congfig.xml中各个标签有规定顺序,这个在后边-->
         <mappers>
             <mapper resource="com/alice/dao/UserMapper.xml"/>
         </mappers>

       

      • junit测试

           @Test
           public void test(){

               //1.获取SqlSession对象
               SqlSession sqlSession = MybatisUtils.getSqlSession();
               //2.执行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导出资源问题

  • 相关阅读:
    vue路由
    vue-cli目录结构介绍
    andriodiphone视频禁止全屏播放
    JS判断Android、iOS或浏览器的多种方法(四种方法)
    vue中移动端自适应方案
    移动端视频不兼容
    vue之router-link
    移动端网页开发注意点
    AWS EC2服务器的HTTPS负载均衡器配置过程
    Kubernetes概念介绍和v1版本部署过程
  • 原文地址:https://www.cnblogs.com/ldy2396/p/14909157.html
Copyright © 2011-2022 走看看