Mybatis基础入门学习笔记(一)

本文是Mybatis的基础入门学习笔记,涵盖了Mybatis框架介绍、ORM概念、Mybatis的快速入门步骤、核心API解析以及映射配置文件的详细说明,包括Resources、SqlSessionFactoryBuilder、SqlSession会话对象等,旨在帮助读者理解Mybatis的基本用法和工作机制。
摘要由CSDN通过智能技术生成

一.Mybatis快速入门

1.1 框架介绍

框架是一款半成品软件,我们可以基于这个半成品软件继续开发,来完成我们个性化的需求!

1.2 ORM介绍

  • ORM(Object Relational Mapping): 对象关系映射

  • 指的是持久化数据和实体对象的映射模式,为了解决面向对象与关系型数据库存在的互不匹配的现象的技术。

  • 具体依赖关系:
    数据库的表(table)----类(class)
    记录(record,行数据)----对象(object)
    字段(field)----对象的属性(attribute)

1.3 原始jdbc操作(查询数据)

public class Test(){
   
	public static void main(String[] args){
   
		//获取驱动
		Class.forName("com.mysql.jdbc.Driver");
		
		//数据库连接信息
		String url="jdbc:mysql://192.168.13.36:3306/db01";	
		String username="root";
		String password="root";
		
		Connection con = DriverManager.getConnection(url,username,password);
		PreparedStatement pst=con.prepareStatement("select * from student");
		ResultSet rs = pst.executeQuery();
		while(rs.next()){
   
			Student stu = new Student();
			stu.setName(rs.getString("name"));
			stu.setAge(rs.getInt("age"));
			stu.setGender(rs.getString("gender"));
			System.out.println(stu);
		}
		rs.close();
		pst.close();
		con.close();
	}
}

1.4 原始jdbc操作的分析

  • 原始 JDBC 的操作问题分析

    ​ 1.频繁创建和销毁数据库的连接会造成系统资源浪费从而影响系统性能。

    2. sql 语句在代码中硬编码,如果要修改 sql 语句,就需要修改 java 代码,造成代码不易维护。
    3. 查询操作时,需要手动将结果集中的数据封装到实体对象中。
    4. 增删改查操作需要参数时,需要手动将实体对象的数据设置到 sql 语句的占位符。 
    
  • 原始 JDBC 的操作问题解决方案

    ​ 1.使用数据库连接池初始化连接资源。

    1. 将 sql 语句抽取到配置文件中。
    2. 使用反射、内省等底层技术,将实体与表进行属性与字段的自动映射
1.5 Mybatis的快速入门

MyBatis开发步骤:

①添加MyBatis的jar包

②创建Student数据表

③编写Studentr实体类

④编写映射文件StudentMapper.xml

⑤编写核心文件MyBatisConfig.xml

⑥编写测试类

1.6.1 环境搭建

1)导入MyBatis的jar包

  • mysql-connector-java-5.1.37-bin.jar
  • mybatis-3.5.3.jar
  • log4j-1.2.17.jar
  1. 创建student数据表
  2. 编写Student实体
public class Student {
   
    private Integer id;
    private String name;
    private Integer age;
    //省略get个set方法
}

4)编写StudentMapper.xml映射文件

<?xml version="1.0" encoding="UTF-8" ?>
<!--MyBatis的DTD约束-->
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<!--
    mapper:核心根标签
    namespace属性:名称空间
-->
<mapper namespace="StudentMapper">
    <!--
        select:查询功能的标签
        id属性:唯一标识
        resultType属性:指定结果映射对象类型
        parameterType属性:指定参数映射对象类型
    -->
    <select id="selectAll" resultType="student">
        SELECT * FROM student
    </select>
</mapper>
  1. 编写MyBatis核心文件
<?xml version="1.0" encoding="UTF-8" ?>
<!--MyBatis的DTD约束-->
<!DOCTYPE configuration PUBLIC 
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值