zoukankan      html  css  js  c++  java
  • MyBatis介绍以及入门程序

    MyBatis

    MyBatis简介

    MyBatis 是iBatis3.0后更名 半自动化(java持久层框架)SQL Map 和 Data Access Object(DAO)
    Hibernate 全自动化持久层框架
    iBatis 是Apache的开源项目 迁移到Google后,更名MyBatis 2013年11月

    MyBatis的优势

    它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理
    例如注册驱动、创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。

    相对来说JDBC的问题

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

    Mybatis解决jdbc编程的问题

    1、数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库连接池可解决此问题。
    解决:在SqlMapConfig.xml中配置数据连接池,使用连接池管理数据库链接。
    2、Sql语句写在代码中造成代码不易维护,实际应用sql变化的可能较大,sql变动需要改变java代码。
    解决:将Sql语句配置在XXXXmapper.xml文件中与java代码分离。
    3、向sql语句传参数麻烦,因为sql语句的where条件不一定,可能多也可能少,占位符需要和参数一一对应。
    解决:Mybatis自动将java对象映射至sql语句,通过statement中的parameterType定义输入参数的类型。
    4、对结果集解析麻烦,sql变化导致解析代码变化,且解析前需要遍历,如果能将数据库记录封装成pojo对象解析比较方便。
    解决:Mybatis自动将sql执行结果映射至java对象,通过statement中的resultType定义输出结果的类型。

    MyBatis的工作原理

    Mybatis通过xml或注解的方式将要执行的各种statement(statement、preparedStatemnt、CallableStatement)
    配置起来,并通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并
    将结果映射成java对象并返回。

    MyBatis的架构

    1、mybatis配置
    SqlMapConfig.xml,此文件作为mybatis的全局配置文件,配置了mybatis的运行环境等信息。
    mapper.xml文件即sql映射文件,文件中配置了操作数据库的sql语句。此文件需要在SqlMapConfig.xml中加载。
    2、通过mybatis环境等配置信息构造SqlSessionFactory即会话工厂
    3、由会话工厂创建sqlSession即会话,操作数据库需要通过sqlSession进行。
    4、mybatis底层自定义了Executor执行器接口操作数据库,Executor接口有两个实现,一个是基本执行器、一个是缓存执行器。
    5、Mapped Statement也是mybatis一个底层封装对象,它包装了mybatis配置信息及sql映射信息等。mapper.xml文件中一个sql对应一个Mapped Statement对象,sql的id即Mapped statement的id。
    6、Mapped Statement对sql执行输入参数进行定义,包括HashMap、基本类型、pojo,Executor通过Mapped Statement在执行sql前将输入的java对象映射至sql中,输入参数映射就是jdbc编程中对preparedStatement设置参数。
    7、Mapped Statement对sql执行输出结果进行定义,包括HashMap、基本类型、pojo,Executor通过Mapped Statement在执行sql后将输出结果映射至java对象中,输出结果映射过程相当于jdbc编程中对结果的解析处理过程。

    MyBatis的入门程序

    1.mybatis下载

    mybaits的代码由github.com管理
    下载地址:https://github.com/mybatis/mybatis-3/releases
    
    mybatis-3.2.7.jar	mybatis的核心包
    lib文件夹		mybatis的依赖包所在
    mybatis-3.2.7.pdf	mybatis使用手册
    

    2.环境搭建

    a.导包
    	mybatis的核心包和依赖包
    	mysql数据库 或者其他数据库的 驱动包
    
    b.创建pojo & 测试类
    
    	注意:类中必须有空参构造函数 
    
    c.创建名为conf的 source folder 
    
    	jdbc.properties
    	log4j.xml
    	SqlMapConfig.xml
    	UserMapper.xml
    
    
    d.UserMapper.xml
    
    	<?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:命名空间 -->
    	<mapper namespace="test">
    		<!-- id:statement的id 或者叫做sql的id-->
    		<!-- parameterType:声明输入参数的类型 -->
    		<!-- resultType:声明输出结果的类型,应该填写pojo的全路径 -->
    		<!-- #{}:输入参数的占位符,相当于jdbc的? -->
    	<select id="getUser" resultType="org.mybatis.User" databaseId="mysql" parameterType="int"> 
    		select * from t_user where id = #{id}
    	</select>
    	</mapper>
    
    e.SqlMapConfig.xml
    
    	<?xml version="1.0" encoding="UTF-8" ?>
    	<!DOCTYPE configuration
    	  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    	 "http://mybatis.org/dtd/mybatis-3-config.dtd">
    	<configuration>
    		<!-- properties:配置引入 properties配置文件 -->
    		<properties resource="jdbc.properties"></properties>
    		<environments default="dev_mysql">
      		<environment id="dev_mysql">
          		<transactionManager type="JDBC"/>
          		<dataSource type="POOLED">
            		<property name="driver" value="${jdbc.driver}"/>
            		<property name="url" value="${jdbc.url}"/>
            		<property name="username" value="${jdbc.user}"/>
            		<property name="password" value="${jdbc.pwd}"/>
          		</dataSource>
        		</environment>
        
        		<environment id="dev_oracle">
          		<transactionManager type="JDBC"/>
          		<dataSource type="POOLED">
            		<property name="driver" value="${oracle.driver}"/>
            		<property name="url" value="${oracle.url}"/>
            		<property name="username" value="${oracle.username}"/>
            		<property name="password" value="${oracle.password}"/>
          		</dataSource>
        		</environment>
    		</environments>
    		<databaseIdProvider type="DB_VENDOR">
    		<property name="MySQL" value="mysql"/>
    		<property name="Oracle" value="oracle"/>
    		</databaseIdProvider>
    		<mappers>
        		<mapper resource="UserMapper.xml"/>
    		</mappers>
    	</configuration>
    

    3.使用&测试

    	package org.junit;
    
    	import java.io.InputStream;
    
    	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 org.mybatis.User;
    
    	public class TestMyBatis {
    
    		@Test
    		public void test1() throws Exception {
    			//加载核心配置文件
    			String resource = "SqlMapConfig.xml";
    			InputStream in = Resources.getResourceAsStream(resource);
    			//创建SqlSessionFactory
    			SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
    			//创建SqlSession 
    			SqlSession sqlSession = sqlSessionFactory.openSession();
    	
    			//执行sql语句
    			User user = sqlSession.selectOne("test.getUser", 3);
    			System.out.println(user);
    		}
    	}
  • 相关阅读:
    Tensorflow 2 flower_photos花卉数据集手动下载、离线安装、本地加载、快速读取
    [CC]ccHObject
    [CC]CC插件初探
    [g2o]一个备忘
    [PCL]keypoint
    [PCL]NDT点云匹配方法
    近邻搜索算法
    点云匹配和ICP算法概述
    [PCL]5 ICP算法进行点云匹配
    [PCL]4 PCL中图像匹配的几个类图
  • 原文地址:https://www.cnblogs.com/nm666/p/8509518.html
Copyright © 2011-2022 走看看