当前位置: 首页 > java >正文

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<Emp> 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 {@Autowiredprivate EmpMapper empMapper;@Testpublic void testFindAll(){List<Emp> 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<Emp> 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 {@Autowiredprivate EmpMapper empMapper;@Testpublic void testFindAll(){List<Emp> emps = empMapper.findAll();emps.forEach(System.out::println);}/** 根据ID删除数据 返回影响行数* */@Testpublic void testDeleteByID(){Integer num =  empMapper.deleteById(2);System.out.println(num);}/** 测试新增数据* */@Testpublic 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);}/** 测试更新数据* */@Testpublic 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);}/** 测试根据用户名和密码查询数据* */@Testpublic 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中文网

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.wyyzs.mapper.EmpMapper"><!--查询所有数据--><select id="findAll" resultType="com.wyyzs.pojo.Emp">select * from emp</select></mapper>

        3.  在mybatis的开发中,倒底使用注解开发还是XML开发?

                使用mybatis的注解,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用xml来配置映射语句,官方说明:入门_MyBatis中文网

九. XML映射文件-辅助配置

        1. 配置XML文件映射文件的位置

                

# 配置mybatis的mapper文件位置
mybatis.mapper-locations=classpath:mapper/*.xml

        2. MybatisX

                MybatisX是一款基于IDEA的快速开发Mybatis的插件,为效率而生。

                

http://www.xdnf.cn/news/8339.html

相关文章:

  • springboot集成日志配置文件
  • rac-rac dg 用role自动启动service
  • 青少年编程与数学 02-020 C#程序设计基础 03课题、开始编程
  • 【Python正则表达式终极指南】从零到工程级实战
  • Spring Boot与Kafka集成实践:从入门到精通
  • AOP的代理模式
  • 非关系型数据库NoSQL
  • CMA软件实验室体系建设中的测试方法部分
  • 【计网】五六章习题测试
  • arcgis js统计FeatureLayer的椭球面积、平面面积
  • 如果请求体不是JSON格式,UserController层会怎样?
  • PCA例题
  • UG903 (v2024.2)的中文版
  • 楼宇自控系统赋予建筑智慧动能,加速智慧低碳建筑建设进程
  • 代码随想录算法训练营第四十八天
  • 昆仑芯超节点创新设计:1U 4 卡高密算力,无缝适配各类机房环境
  • Linux之Ext系列文件系统(含动静态库)
  • ansible剧本和角色的使用,部署lnmp
  • 搭建自己的语音对话系统:开源 S2S 流水线深度解析与实战
  • 李宏毅《深度学习》:Self-attention 自注意力机制
  • redis 进行缓存实战-18
  • 第J2周:ResNet50V2 算法实战与解析
  • Python爬虫(35)Python爬虫高阶:基于Docker集群的动态页面自动化采集系统实战
  • 内网渗透——红日靶场四
  • 从逻辑视角学习信息论:概念框架与实践指南
  • 127. 单词接龙
  • WDS 无线桥接
  • 交安安全员:交通工程安全领域的关键角色
  • 无人机桥梁检测如何通过数据存储、边缘AI、无线通讯等技术路线,提升检测效率
  • Seata分布式事物案例及详解