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

【mybaits基础使用】--什么是mybaits

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

【mybaits基础使用】--什么是mybaits

前言: 在总结这边博客之前其实自己已经在使用mybatis了,但是对于mybatis只是停留在了一个简单的使用上面,那么我们为什么不使用JDBC?而要用Mybatis? 下面就来介绍一下

JDBC存在的问题:
  1. 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库连接池可解决此问题。
  2. Sql 语句在代码中硬编码,造成代码不易维护,实际应用 sql 变化的可能较大,sql 变动需要改变 java 代码。
  3. 使用 preparedStatement 向占位符号传参数存在硬编码,因为 sql 语句的 where 条件不一定,可能多也可能少,修改 sql 还要修改代码,系统不易维护。
  4. 对结果集解析存在硬编码(查询列名),sql 变化导致解析代码变化,系统不易维护,如果能将数据库记录封装成 pojo 对象解析比较方便
什么是Mybatis:

    mybatis是一款持久层框架,避免了几乎所有的JDBC代码和手动设置参数的过程

什么是持久化?

    把数据(即内存中的对象)保存到可永久保存的存储设备中,

为什么要进行持久化服务?

    内存断电之后数据会丢失,但是有一些对象是无论如何都不会丢失的,内存相比硬盘来说价格过于昂贵

下面我们用一个简单的例子来介绍mybatis的使用

首先创建一个Maven项目:
  • 导入依赖:

   org.mybatis
   mybatis
   3.5.2


   mysql
   mysql-connector-java
   5.1.47

  • 编写Mybatis核心配置文件:



   
       
           
           
               
               
               
               
           
       
   
   
       
   

environments表示多环境,一个配置文件可以有多个环境,比如测试,开发,生产,每一个environment都有自己的id

default表示默认环境

  • 创建实体类:
public class User {  
   private int id;  //id
   private String name;   //姓名
   private String pwd;   //密码
   
   //构造,有参,无参
   //set/get
   //toString()
}
  • 编写Mapper接口:
import com.kuang.pojo.User;
import java.util.List;
public interface UserMapper {
   List selectUser();
}
  • 编写Mapper.xml配置文件



 

  • 最后加载主配置文件:
public class MyTest {
   @Test
   public void selectUser() {
       SqlSession session = MybatisUtils.getSession();
       //方法一:
       //List users = session.selectList("com.kuang.mapper.UserMapper.selectUser");
       //方法二:
       UserMapper mapper = session.getMapper(UserMapper.class);
       List users = mapper.selectUser();
 
       for (User user: users){
           System.out.println(user);
      }
       session.close();
  }
}

        sqlSessionFactoryBuilder  创建  sqlSessionFactory

        sqlSessionFactory创建sqlSession

         在这里,SqlSessionFactoryBuilder 用于创建 SqlSessionFacoty,SqlSessionFacoty 一旦创建完成就不需要 SqlSessionFactoryBuilder 了,因为 SqlSession 是通过 SqlSessionFactory 生产,所以可以将 SqlSessionFactoryBuilder 当成一个工具类使用,最佳使用范围是方法范围即方法体内局部变量。

        SqlSessionFactory 是一个接口,接口中定义了 openSession 的不同重载方法,SqlSessionFactory 的最佳使用范围是整个应用运行期间,一旦创建后可以重复使用,通常以单例模式管理 SqlSessionFactory

  • 创建MybatisUtils
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;
 
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 (IOException e) {
           e.printStackTrace();
      }
  }

 

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

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

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