Mybatis-入门程序、 数据库连接池、XML映射配置文件、MybatisX
一. Mybatis
1. Mybatis是一款优秀的持久层框架,用于简化jdbc的开发
2. Mybatis本是Apache的一个开源项目iBatis,2010年这个项目有Apache迁移到了Google code,并且改名为MyBatis,2013年11月迁移到Github
3.官网:MyBatis 3 | 简介 – mybatishttps://mybatis.org/mybatis-3/zh_CN/index.html
二. MyBaits-入门程序
1. 创建SpringBoot工程,引入MyBatis相关依赖
2. 准备数据库表emp、实体类user
3. 配置Mybatis(在application.prooerties中数据库连接信息)
4. 编写MyBatis程序:编写MyBatis的持久层接口,定义SQL(注解/XML)
package com.wyyzs.mapper; import com.wyyzs.pojo.Emp; import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Select; import java.util.List; @Mapper //应用程序在运行时,会自动创建这个接口的实现类对象,并把对象注入到spring容器中 public interface EmpMapper { /* * 查询所有数据 * */ @Select("select * from emp") public List findAll(); }
package com.wyyzs.pojo; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import java.util.Date; @Data //getter setter toString @AllArgsConstructor //全参构造 @NoArgsConstructor //无参构造 public class Emp { Integer id; String username; String password; String name; Integer gender; String phone; Integer job; Integer salary; Date entry_date; String image; Date create_time; Date update_time; }
package com.wyyzs; import com.wyyzs.mapper.EmpMapper; import com.wyyzs.pojo.Emp; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import java.util.List; @SpringBootTest //SpringBoot单元测试的注解 - 当前测试类当中的测试方法运行时,会启动整个SpringBoot应用 - ioc容器 class JavaMyBatisApplicationTests { @Autowired private EmpMapper empMapper; @Test public void testFindAll(){ List emps = empMapper.findAll(); emps.forEach(System.out::println); } }
注意:测试类所在的包需要与引导类包名相同(或放在引导类所在包的子包下)
三. Mybatis辅助配置-配置SQL提示
四. 辅助配置-配置mybatis的日志输出
1. 默认情况下,在mybatis中执行SQL语句时,并不能看到SQL语句的执行日志,在
application.properties加入以下配置,即可查看日志
# mybatis的日志输出 (输出到控制台) mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
五. 数据库连接池
1. 数据库连接池是一个容器,负责分配、管理数据库连接(Connection)
2.它允许应用程序重复使用一个现有的数据库连接,而不是再建立一个
3. 释放空闲超过最大空闲时间的连接,来避免因为没有释放连接而引起的数据库连接遗漏
4. 优势:(1) 资源重用 (2) 提升系统响应速度 (3) 避免数据库连接遗漏
5. 标准接口:DataSource
sun公司提供的数据连接池接口,由第三方组织实现此接口
功能:获取连接 Connection getConnection() throews SQLException;
6. Druid(德鲁伊)
(1) Druid连接池是阿里巴巴开源数据库连接池项目;
(2) 功能强大,性能优秀,是Java语言最好的数据库连接池之一;
7. 切换数据库连接池
六. Mybatis中 #号 与 $ 号
例如:@Delete("delete from emp where id = #{id}")
@Select("select id,name,score from ${tableName} order by ${sortField}") --很少使用
七. Mybatis-增删改查操作
package com.wyyzs.mapper; import com.wyyzs.pojo.Emp; import org.apache.ibatis.annotations.*; import java.util.List; @Mapper //应用程序在运行时,会自动创建这个接口的实现类对象,并把对象注入到spring容器中 public interface EmpMapper { /* * 查询所有数据 * */ @Select("select * from emp") public List findAll(); /* * 根据ID删除数据 * */ @Delete("delete from emp where id = #{id}") public Integer deleteById(Integer id); /* * 新增数据 * */ @Insert("insert into emp(username,password,name,gender,phone,job,salary,entry_date,image,create_time,update_time) " + "values(#{username},#{password},#{name},#{gender},#{phone},#{job},#{salary},#{entry_date},#{image},#{create_time},#{update_time})") public Integer insert(Emp emp); /* * 根据ID更新数据 * */ @Update("update emp set username=#{username},password=#{password},name=#{name},gender=#{gender},phone=#{phone},job=#{job},salary=#{salary},entry_date=#{entry_date}," + "image=#{image},create_time=#{create_time},update_time=#{update_time} where id=#{id}") public Integer update(Emp emp); /* * 根据用户名和密码查询数据 * @Param 注解:将参数传递给SQL语句 作用是为接口的方法形参起名字的 * 说明:如果是基于官方骨架创建的springboot项目,接口编译时会保留方法的形参名,@Param注解可以省略(#{形参名}) * public Emp findByUsernameAndPassword(String username, String password); * */ @Select("select * from emp where username=#{username} and password=#{password}") public Emp findByUsernameAndPassword(@Param("username") String username, @Param("password") String password); }
package com.wyyzs; import com.wyyzs.mapper.EmpMapper; import com.wyyzs.pojo.Emp; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import java.util.Date; import java.util.List; @SpringBootTest //SpringBoot单元测试的注解 - 当前测试类当中的测试方法运行时,会启动整个SpringBoot应用 - ioc容器 class JavaMyBatisApplicationTests { @Autowired private EmpMapper empMapper; @Test public void testFindAll(){ List emps = empMapper.findAll(); emps.forEach(System.out::println); } /* * 根据ID删除数据 返回影响行数 * */ @Test public void testDeleteByID(){ Integer num = empMapper.deleteById(2); System.out.println(num); } /* * 测试新增数据 * */ @Test public void testInsert(){ Emp emp = new Emp(null,"laoshu","123456","老鼠",1,"14785209630",1,10000,new Date(),"1.jpg",new Date(),new Date()); Integer num = empMapper.insert(emp); System.out.println(num); } /* * 测试更新数据 * */ @Test public void testUpdate(){ Emp emp; emp = new Emp(3,"nvqiang","123456","女枪",1, "13333456789",1,10000,new Date(),"1.jpg",new Date(),new Date()); Integer num = empMapper.update(emp); System.out.println(num); } /* * 测试根据用户名和密码查询数据 * */ @Test public void testFindByUsernameAndPassword(){ Emp emp = empMapper.findByUsernameAndPassword("nvqiang","123456"); System.out.println(emp); } }
@Param 注解:将参数传递给SQL语句 作用是为接口的方法形参起名字的
如果Mapper接口形参中只有一个参数,可以不使用Param 注解。
如果Mapper接口形参中有多个参数,需要通过@Param 注解为每一个形参起名称(说明:如果是基于官方骨架创建的springboot项目,接口编译时会保留方法的形参名,@Param注解可以省略(#{形参名}))
字节码文件中保留了参数
八. XML映射配置文件
1. 在mybatis中,既可以通过注解配置SQL 语句,也可以通过XML配置文件配置SQL语句。
2.默认规则:
(1) XML映射文件的名称与mapper接口名称一致,并且将xml映射文件和mapper接口放置在相同包下(同包同名)
(2) XML映射文件的namespace属性为Mapper接口全限定名一致
(3) XML映射文件中SQL语句的ID与mapper接口中的方法名一致,并保持返回类型一致
入门_MyBatis中文网
select * from emp
3. 在mybatis的开发中,倒底使用注解开发还是XML开发?
使用mybatis的注解,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用xml来配置映射语句,官方说明:入门_MyBatis中文网
九. XML映射文件-辅助配置
1. 配置XML文件映射文件的位置
# 配置mybatis的mapper文件位置 mybatis.mapper-locations=classpath:mapper/*.xml
2. MybatisX
MybatisX是一款基于IDEA的快速开发Mybatis的插件,为效率而生。