Mybatis基础

一. Mybatis基础

1. 相关概念

1.1框架介绍

  • 框架是一款半成品软件,我们可以基于这个半成品软件继续开发,来完成我们个性化的需求!
  • 简单来说, 就是"框架把一些不变的东西提前写好, 让我们能更快更好的完成程序的开发"

1.2 ORM介绍

  • ORM(Object Relational Mapping): 对象关系映射
    • object:指的是实体对象,javabean
    • relational:指的是关系型数据库,比如mysql
    • Mapping: 映射,一 一对应的关系
  • 简单来说,ORM可以实现对象与数据库表之间的自动映射

1.3 Mybatis

  • mybatis 是一个优秀的基于java的, 并且实现了ORM映射的持久层框架,它内部封装了jdbc

  • mybatis通过xml或注解的方式实现对数据库的持久化操作

  • MyBatis官网地址:http://www.mybatis.org/mybatis-3/

2. 快速入门

2.1 MyBatis开发步骤

①添加MyBatis的jar包

mysql-connector-java-5.1.37-bin.jar
mybatis-3.5.3.jar
og4j-1.2.17.jar

②编写实体类(对应数据库中的表)

//学生类
//该类要和数据库表进行一一对应
public class Student {
     
    private Integer id;
    private String name;
    private Integer age;
    //省略get个set方法
}

③编写核心配置文件SqlMapConfig.xml

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


<!--configuration 核心根标签-->
<configuration>
    <!--environments配置数据库环境,环境可以有多个。default属性指定使用的是哪个-->
    <environments default="mysql">
        <!--environment配置数据库环境  id属性唯一标识-->
        <environment id="mysql">
            <!-- transactionManager事务管理。 type属性,采用JDBC默认的事务-->
            <transactionManager type="JDBC"></transactionManager>
            <!-- dataSource数据源信息   type属性 连接池-->
            <dataSource type="POOLED">
                <!-- property获取数据库连接的配置信息 -->
                <property name="driver" value="com.mysql.jdbc.Driver" />
                <property name="url" value="jdbc:mysql://192.168.59.143:3306/数据库表名" />
                <property name="username" value="数据库账户" />
                <property name="password" value="数据库密码" />
            </dataSource>
        </environment>
    </environments>

    <!-- mappers引入映射配置文件 -->
    <mappers>
        <!-- resource属性指定映射配置文件的位置 -->
        <mapper resource="StudentMapper.xml"/>
    </mappers>
</configuration>

④编写映射配置文件

<?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:查询功能的标签.   insert:添加  update:修改  delete:删除
        id属性:唯一标识
        resultType属性:指定结果映射对象类型
        parameterType属性:指定参数映射对象类型
    -->
    <select id="selectAll" resultType="com.itheima.bean.Student">
        SELECT * FROM student
    </select>
    
</mapper>

⑤编写测试类

@Test
public void selectAll() throws Exception{
     
    //1.加载核心配置文件
    InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");

    //2.获取SqlSession工厂对象
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);

    //3.通过SqlSession工厂对象获取SqlSession对象
    SqlSession sqlSession = sqlSessionFactory.openSession();

    //4.执行映射配置文件中的sql语句,并接收结果(参数是StudentMapper.xml中的selectAll)
    List<Student> list = sqlSession.selectList("StudentMapper.selectAll");

    //5.处理结果
    for (Student stu : list) {
     
        System.out.println(stu);
    }

    //6.释放资源
    sqlSession.close();
    is.close();
}

3. 映射配置文件

3.1 配置信息

<?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="StudentMapper">
   
    <insert id="insert" parameterType="student">
        INSERT INTO student VALUES (#{
     id},#{
     name},#{
     age})
    </insert>

    <update id="update" parameterType="student">
        UPDATE student SET name = #{
     name},age = #{
     age} WHERE id = #{
     id}
    </update>

    <delete id="delete" parameterType="int">
        DELETE FROM student WHERE id = #{
     id}
    </delete>
     
    <select id="selectAll" resultType="student">
        SELECT * FROM student
    </select>

    <select id="selectById" resultType="student" parameterType="int">
        SELECT * FROM student WHERE id = #{
     id}
    </select>

</mapper

3.2 注意事项

//简单类型:基本数据类型+String  	复杂类型:除了基本数据类型和String
1.参数是简单类型,则parameterType可以省略
2.参数如果只有一个,且是简单类型时,#{
     id}可以随便写,都可以获取参数的值
3.如果参数是复杂类型,则#{
     id}就相当于调用参数的getId方法,获取对应的参数值
4.返回值是简单类型,则resultType可以省略
5.返回值是集合类型,则resultType只写集合中元素的数据类型

4. 核心配置文件

4.1 引入外部properties

① jdbc.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://192.168.59.143:3306/db1
username=rooot
password=itheima

② 引入配置文件

<!--在MyBatis的核心配置文件中,引入数据库连接的配置文件-->
<properties resource="jdbc.properties"/>

③ 获取配置信息

<!-- 在MyBatis的核心配置文件中, 获取引入的properties文件中的配置信息 -->
<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="username" value="${username}" />
<property name="password" value="${password}" />

4.2 起别名

4.2.1 语法

<!--起别名-->
<typeAliases>
    <!-- 给Student类起别名为"student" -->
    <typeAlias type="com.itheima.bean.Student" alias="student"/>
    <!-- 给com.itheima.bean包下所有的类起别名,别名为类名的小写名字 -->
    <!--<package name="com.itheima.bean"/>-->
    </typeAliase>
</typeAliases>

4.2.1 作用

当给实体类起别名后, 在MyBatis映射配置文件中的参数或返回值中, 可以直接使用别名, 并且别名不区分大小写

5. 补充-selectKey标签

5.1 概述

selectKey标签只能用在增删改语句中, 它可以在"增删改"语句执行前后, 增加对应操作.

5.2 案例

<insert id="insert" parameterType="student">
    <selectKey keyProperty="id" order="AFTER" >
        SELECT LAST_INSERT_ID()
    </selectKey>
    INSERT INTO student VALUES (#{
     id},#{
     name},#{
     age})
</insert>

你可能感兴趣的:(Mybatis,java)