Mybatis框架----简介

什么是Mybatis

Mybatis是一款优秀的持久层框架,用于简化JDBC开发,MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的需要。

Mybatis的核心思想

MyBatis 的核心思想是将 SQL 语句从应用程序代码中解耦出来,通过配置文件(通常是 XML 文件)或注解的方式将 SQL 语句与 Java 代码分离,从而提高了代码的可维护性和可重用性。MyBatis 提供了强大的映射功能,可以将数据库中的表映射为 Java 对象,也可以将 Java 对象映射回数据库表,实现了对象关系映射(ORM)的功能。

持久层

  • 负责将数据保存到数据库的那一层代码
  • JavaEE三层架构:表现层,业务层,持久层

框架

  • 框架就是一个半成品软件,是一套可重用的,通用的,软件基础代码模型
  • 在框架的基础上构建软件编写更加高效,规范,通用,可扩展

官网:入门_MyBatis中文网icon-default.png?t=O83Ahttps://mybatis.net.cn/getting-started.html

 JDBC缺点

  1. 硬编码

        硬编码是指代码中字符串信息,但是字符串的信息可能会发生变动

        注册驱动,获取连接

        sql语句 

  1. 操作繁琐

        手动设置参数

        手动封装结果集

Mybatis简化

  1. 硬编码------写在配置文件中
  2. 操作繁琐------自动完成

Mybatis快速入门

查询user表中的所有数据

1.把user表中的数据查询出来

2.将数据装到user对象中

3.再将一个个对象装到集合中去

步骤
  1. 创建user表,添加数据
  2. 创建模块,导入坐标
  3. 编写Mybatis核心配置文件-------->替换连接信息,解决硬编码问题
  4. 编写sql映射文件----->统一管理sql语句,解决硬编码问题
  5. 编码
    1. 定义pojo类
    2. 加载核心配置文件,获取SqlSessionFactory对象
    3. 获取SqlSession对象,执行SQ L语句
    4. 释放资源

1.创建maven项目mybatis01

2.在pom.xml文件中引入mybatis所需jar文件

<!--mybatis配置包-->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.2.8</version>
    </dependency>

    <!--mysql数据库驱动包-->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.30</version>
    </dependency>

3.在resources下创建xml文件mybatis.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">

 4.准备工作,在resources下放入JDBC.properties(下面是JDBC.properties文件内容)

mysql.driver=com.mysql.jdbc.Driver
mysql.url=jdbc:mysql://127.0.0.1:3306/smbms?allowMultiQueries=true&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
mysql.username=root
mysql.pwd=123456

 5.创建com.hz.pojo和com.hz.dao,创建实体类Provider和ProviderDao接口

6. 编写mybatis.xml主配置文件 读取JDBC.properties,加载数据源

<configuration>
    <!--需要变为 mybatis主配置文件 -->
    <!-- 读取jdbc.properties,加载数据源-->
    <!--加载jdbc.properties-->
    <properties resource="JDBC.properties"></properties>
    <!--获得数据源-->
    <environments default="smbms">
        <environment id="smbms">
            <!--事物配置-->
            <transactionManager type="JDBC"></transactionManager>
            <!--数据库连接池-->
            <dataSource type="POOLED">
                <property name="driver" value="${mysql.driver}"/>
                <property name="url" value="${mysql.url}"/>
                <property name="username" value="${mysql.username}"/>
                <property name="password" value="${mysql.pwd}"/>
            </dataSource>
        </environment>
    </environments>
    <!--扫描mapper文件-->
    <mappers>
        <mapper resource="mapper\ProviderMapper.xml"/>
    </mappers>


</configuration>

7. 在resources下创建mappers文件夹,并创建ProviderMapper.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">

8.编写ProviderMapper.xml文件,重写接口中findProviderById方法

<mapper namespace="com.hz.dao.ProviderDao">
<!-- 注意:namespace为实现的接口-->
    <!--
    id:要实现的方法名
    resultType:返回值类型
    -->
    <select id="findProviderById" resultType="com.hz.pojo.Provider">
        select id,proCode,proName from smbms_provider where id=2
    </select>
</mapper>

9. 创建main方法进行测试

import com.hz.dao.ProviderDao;
import com.hz.pojo.Provider;
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 Test {
	public static void main(String[] args) {

		try {
			//读取mybatis.xml主配置文件 获得字节流对象
			InputStream is = Resources.getResourceAsStream("mybatis.xml");
			//创建工厂  将字节流对象放入  获得 数据源工厂
			SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
			//获得数据源SqlSession
			SqlSession sqlSession = sqlSessionFactory.openSession();
			//获得providerdao实例
			ProviderDao providerDao = sqlSession.getMapper(ProviderDao.class);
			//调用方法
			Provider provider = providerDao.findProviderById();
			System.out.println(provider.toString());

			//关闭资源
			sqlSession.close();
		} catch (Exception e) {
			throw new RuntimeException(e);
		}

	}
}

测试成功说明配置完成!!


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值