Mybatis简介与简单测试

原始jdbc操作的分析笔记:

数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能
sql 语句在代码中硬编码,造成代码不易维护,实际应用sql变化的可能较大,sql 变动需要改变java代码.
查询操作时,需要手动将结果集中的数据手动封装到实体中。插入操作时,需要手动将实体的数据设到sq|语句的占位
符位置

mybatis:

使用数据库连接池初始化连接资源,将sq|语句抽取到xm配置文件中,使用反射、内省等底层技术,自动将实体与表进行属性与字段的自动映射, 采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装

ORM

ORM慨念:对象关系映射(Object Relational Mapping,简称ORM)
ORM能将程序中的对象自动持久化到关系数据库中。

常见的ORM框架: Mybatis 、Hibernate
a)Mybatis是一-种半自动化的ORM框架:在Mybatis中还是需要书写sql语句
b) Hibernate是一 -种全自动化的ORM框架:在Hibernate中不需要书写sql语句,与之代替的是HQL

快速入门操作:

MyBatis官网地址

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
导入jar
mybatis的jar包下载地址:https://github.com/mybatis/mybatis-3/releases

mybatis和Spring整合jar包下载地址:https://github.com/mybatis/spring/releases
在这里插入图片描述
在这里插入图片描述
右键bulid path->add to bulid path
在这里插入图片描述
新建源文件夹:
在这里插入图片描述
resource中建主配置文件: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">
        
<configuration>
    <!--环境配置,连接的数据库,这里使用的是MySQL-->
    <environments default="mysql"><!--default="mysql"与id保持一致 -->
        <environment id="mysql">
            <!--1.指定事务管理的类型,这里简单使用Java的JDBC的提交和回滚设置,type值统一使用JDBC-->
            <transactionManager type="JDBC"></transactionManager>
            <!--2.dataSource 指连接源配置,POOLED是JDBC连接对象的数据源连接池的实现-->
            <dataSource type="POOLED"><!-- type="POOLED"也是固定值 -->
                <property name="driver" value="com.mysql.jdbc.Driver"></property>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/read"></property>
                <property name="username" value="root"></property>
                <property name="password" value=""></property>
            </dataSource>
        </environment>
    </environments>
</configuration>   

书写局部配置文件,局部配置文件的名称与dao层的类名保持一致,局部配置文件用来保存sql语句

在 JDBC中 使用String变量来配置,而mybatis中使用局部文件配置

package com.java.dao.impl;

public class MenuDaoImpl {
	
	public void selectAll() {
	}

}

在这里插入图片描述
实体类:

package com.java.entity;

public class Item {
private int id;
private String name;
private int pid;
加上对应的get,set方法,tostring方法
}
<?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">
<mapper namespace="com.java.dao.impl.MenuDaoImpl"><!-- namespace="对应类的权限定类名" -->
<!-- 在mybatis中严格区别增删改查,操作必须放在对应的标签 -->
    <select id="selectAll" parameterType="int" resultType="com.java.entity.Item">
    <!-- id与方法中的名称保持一致 -->
        select * from `menu` 
    </select>
</mapper>

最后一步配置,将主配置文件与局部配置文件关联

<?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>
    <!--环境配置,连接的数据库,这里使用的是MySQL-->
    <environments default="mysql"><!--default="mysql"与id保持一致 -->
        <environment id="mysql">
            <!--1.指定事务管理的类型,这里简单使用Java的JDBC的提交和回滚设置,type值统一使用JDBC-->
            <transactionManager type="JDBC"></transactionManager>
            <!--2.dataSource 指连接源配置,POOLED是JDBC连接对象的数据源连接池的实现-->
            <dataSource type="POOLED"><!-- type="POOLED"也是固定值 -->
                <property name="driver" value="com.mysql.jdbc.Driver"></property>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/read"></property>
                <property name="username" value="root"></property>
                <property name="password" value=""></property>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <!--这是告诉Mybatis区哪找持久化类的映射文件,对于在src下的文件位置
           如:/mybatis1/src/com/java/dao/impl/MenuDaoImpl.xml去掉至src的部分-->
        <mapper resource="com/java/dao/impl/MenuDaoImpl.xml"></mapper>
    </mappers>
</configuration>       

启动测试

package com.java.dao.impl;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

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.junit.Test;

import com.java.entity.Item;

public class MenuDaoImpl {
	
	
	@Test
	public void selectAll() throws IOException {
		//执行sql语句
		
		
		//读取配置文件
        InputStream is = Resources.getResourceAsStream("mybatis.xml");
        //初始化mybatis,创建SqlSessionFactory类实例
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        //创建Session实例
        SqlSession session = sqlSessionFactory.openSession();
        

        //namespace.id
        List<Item> lists=session.selectList("com.java.dao.impl.MenuDaoImpl.selectAll");
        for(Item item :lists) {
        	System.out.println(item);
        }
       
        //提交事务
        session.commit();
        //关闭Session
        session.close();
	}

}

@Test
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
运行结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值