ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

ssm-mybatis入门

2021-08-10 18:03:35  阅读:160  来源: 互联网

标签:xml mapper String UserMapper ssm mybatis public 入门


ssm-mybatis入门

简介

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。 MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

官网:https://mybatis.org/mybatis-3/zh/index.html

hello world入门

  1. 新建工程
  2. pom文件中添加依赖
  3. 参照官方说明,在resources下新建mybatis-config.xml并配置mysql连接参数,参考地址:
  4. https://mybatis.org/mybatis-3/zh/getting-started.html
  5. 编写mybatis工具类
  6. package com.zx.demo.utils;
    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.InputStream;
    public class MybatisUtils {
        /**
         * 一次创建多次使用避免反复创建,类似于数据库连接池
         */
        private static SqlSessionFactory sqlSessionFactory;
        static {
            try {
                String resource = "mybatis-config.xml";
                InputStream inputStream = Resources.getResourceAsStream(resource);
                sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        public static SqlSession getSession() {
            return sqlSessionFactory.openSession();
        }
    }
    工具类用到了三个对象:SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession
    • SqlSessionFactoryBuilder: 作用是读取mybatis-config.xml配置并构造出SqlSessionFactory对象,之后销毁即可不用长期保留。
    • SqlSessionFactory: SqlSessionFactoryBuilder根据配置文件构造出来的对象,类似于连接池,作用域为整个应用生命周期,应长期持有不释放。
    • SqlSession: SqlSessionFactory构造出来的对象,表示一次会话连接,线程不安全因此在生命周期为当前方法,使用完及时关闭释放。
  7. 创建pojo和mapper(dao)
  8. package com.zx.demo.pojo;
    public class User {
        private String id;
        private String name;
        private String sex;
        public String getId() {
            return id;
        }
        public void setId(String id) {
            this.id = id;
        }
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        public String getSex() {
            return sex;
        }
        public void setSex(String sex) {
            this.sex = sex;
        }
        @Override
        public String toString() {
            return "User{" +
                    "id='" + id + '\'' +
                    ", name='" + name + '\'' +
                    ", sex='" + sex + '\'' +
                    '}';
        }
    }
    
    package com.zx.demo.mapper;
    import com.zx.demo.pojo.User;
    import java.util.List;
    public interface UserMapper {
        List getAll();
    }
    
  9. 在mapper目录下创建sql映射语句配置文件UserMapper.xml
  10. 在mybatis-config.xml配置文件中,注册UserMapper.xml
  11. 在pom.xml文件中配置,将UserMapper.xml文件一起打包输出
  12. 测试
  13.     @Test
        public void getAll() {
            SqlSession session = MybatisUtils.getSession();
            UserMapper mapper = session.getMapper(UserMapper.class);
            List list = mapper.getAll();
            for (User user : list) {
                System.out.println(user);
            }
            session.close();
        }

可能遇到的问题:

  1. org.apache.ibatis.binding.BindingException
  2. org.apache.ibatis.binding.BindingException: Type interface com.zx.demo.mapper.UserMapper is not known to the MapperRegistry.
    编写完mapper.xml后,忘记在mybatis-config.xml配置文件中,注册UserMapper.xml,导致mybatis找不到该mapper

  3. Could not find resource com/zx/demo/mapper/UserMapper.xml
  4. maven运行和打包时,默认不会将UserMapper.xml包装到输出目录,需要在pom.xml文件中进行配置

标签:xml,mapper,String,UserMapper,ssm,mybatis,public,入门
来源: https://www.cnblogs.com/zhoux123/p/15125158.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有