mybatis框架搭建、mybatis打印日志设置、参数传递使用、myatis插件MyBatisX

本文主要是介绍mybatis框架搭建、mybatis打印日志设置、参数传递使用、myatis插件MyBatisX,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、框架

就是对技术的封装,将基础的技术进行封装,让程序员可以快速的使用,提高效率。

Java后端框架:

mybatis:对jdbc进行封装 

spring:对整个Java后端架构进行管理的

springweb:对web层(servlet)进行封装

springboot:对spring框架的搭建进行封装

二、mybatis背景

mybatis原来是apache下面的一个开源项目,名为ibatis,2010年开发团队转移到谷歌旗下,改名为mybatis。

mybatis介绍:mybatis是一个优秀的数据持久层框架(dao层  数据访问层  数据持久层)

是一个对jdbc进行的封装,避免了jdbc手动设置参数,手动映射结果的操作

mybatis将jdbc中的接口进行封装,提供了它自己的类和接口实现

可以使用xml配置和注解的方式,将数据库中记录自动映射到Java对象中,是一种ORM实现(对象关系映射)将可以自动将数据映射到对象中的这种框架,也称为ORM框架

mybatis还提供了动态sql和数据缓存

三、mybatis搭建

1、创建一个maven项目

2、导入mybatis依赖的jar包,在pom。xml中进行配置

        <!--mybatis--><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.2</version></dependency>

3、创建一个全局的mybatis配置文件,配置数据库连接等配置

在rescources下创建一个普通文件(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"><!--mybatis核心全局配置文件-->
<configuration>
<settings><!--配置日志--><setting name="logImpl" value="STDOUT_LOGGING"/><!--开启驼峰命名自动映射--><setting name="mapUnderscoreToCamelCase" value="true"/>
</settings><!--为类配置别名--><typeAliases><!-- <typeAlias type="com.ffyc.mybatispro.model.Admin" alias="Admin"></typeAlias>--><package name="com.ffyc.mybatispro.model"/></typeAliases><!--配置数据库连接相关信息--><environments default="development"><environment id="development"><transactionManager type="JDBC"/><!--type="POOLED" 使用数据库连接池功能 ,默认创建了10个链接对象,减少频繁创建链接对象--><dataSource type="POOLED"><!--数据库连接配置--><property name="driver" value="com.mysql.cj.jdbc.Driver" /><property name="url" value="jdbc:mysql://127.0.0.1:3306/ssmdb?serverTimezone=Asia/Shanghai" /><property name="username" value="root" /><property name="password" value="root"/></dataSource></environment></environments><!--注册映射文件--><mappers><mapper resource="mappers/AdminMappers.xml"></mapper></mappers></configuration>

数据库连接池

连接数据库,每次访问数据库的时候,创建一个Connection用完关闭

但是访问量大了之后,每次都要创建新的连接对象,用完关闭,比较耗时

使用数据库连接池,在池(集合)中先创建一些连接对象,用户访问时,就直接池中获取一个链接对象,用完不销毁,还会池中,这样就减少频繁创建销毁对象

使用数据库连接池功能,默认创建了10个对现象,减少频繁创建连接对象

4、创建数据库创建表,创建数据

5、创建一个访问的接口

6、创建sql映射文件

在rescources下创建一个包(Mappers),包下创建一个普通文件(AdminMappers.xml)文件名可以自己进行修改

7、测试mybatis

1、读取mybatis配置文件 

 Reader reader= Resources.getResourceAsReader("mybatis.xml");
//"mybatis.xml"是对mybatis的配置文件名

2、创建 SqlSessionFactory

//2.创建SqlSessionFactory
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);

3、创建 SqlSession

//3.创建 SqlSession
SqlSession sqlSession=sqlSessionFactory.openSession();

4、获得接口代理对象

//4创建接口代理对象
AdminDao adminDao =  sqlSession.getMapper(AdminDao.class);

sql映射文件和接口对应关系

四、 mybatis日志

配置日志

<settings><setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>

 

在配置时,按照规定的顺序进行配置 

五、 参数传递

单值传递

 /*一个值传参数*/Admin findAdminByid(int id);void deleteAdmin(int id);Admin findAdminByAccount(String account);

 相对于的映射文件中的配置

  <select id="findAdminByid" parameterType="int" resultType="Admin">select * from admin where id =#{id}
</select><delete id="deleteAdmin" parameterType="int">delete from admin where id = #{id}</delete><select id="findAdminByAccount" parameterType="string" resultType="Admin">select * from admin where account =#{account}</select>

多值传递

使用@Param进行值的绑定

 /*多个值传参数*/Admin login(@Param("acc") String account,@Param("pwd") String password);

相对于的映射文件中的配置

 <select id="login" resultType="Admin">select * from admin where account=#{acc} and password=#{pwd}</select>

也可以是对象传参

 /*对象传参数*/Admin login1(Admin admin);

 相对于的映射文件中的配置

<select id="login1" parameterType="admin" resultType="Admin">select * from admin where account=#{account} and password=#{password}</select>

 这里account和password是Admin中的属性

六、mybatis使用示例(新增、修改、删除)

数据库事务:是数据库的一种管理机制,是对一次连接数据库过程的管理操作,保证一次操作中,执行的多条sql,要么都成功执行,要么都不执行。

因此,在Java中执行新增,修改,删除操作时都要进行手动提交事务(

sqlSession.commit();//提交数据库事务,当我们的程序代码块没有任何问题时,在向数据库提交事务操作,数据库才会执行sql,出现异常不提交事务

新增示例:(单表操作)

1、定义新增接口

package com.ffyc.mybatispro.dao;
import com.ffyc.mybatispro.model.Admin;
import java.util.List;
public interface AdminDao {/*对象传参数*/void insertAdmin(Admin admin);
}

2、在sql映射文件中写sql语句

    <insert id="insertAdmin" parameterType="Admin" useGeneratedKeys="true" keyProperty="id" keyColumn="id">insert into admin(account,password,gender) values(#{account},#{password},#{gender})</insert>
useGeneratedKeys="true":返回自增主键
keyProperty="id":第一接收属性keyColumn="id":数据库列单表查询,返回的结果mybatis可以自动将一条记录映射到Java对象中
要求:列名和对象属性一致

3、单元测试(程序员使用的测试方法,以方法为单位)

所以需要引入junit依赖

          <dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>provided</scope></dependency>
 @Testpublic void insert(){//1.mybatis读取配置文件Reader reader= Resources.getResourceAsReader("mybatis.xml");//2.创建SqlSessionFactorySqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);//SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁//3.创建 SqlSessionSqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话System.out.println("新增");Admin admin=new Admin();admin.setAccount("aaa");admin.setPassword("123");admin.setGender("男");AdminDao adminDao=sqlSession.getMapper(AdminDao.class);adminDao.insertAdmin(admin);//保存数据后,需要立刻拿到这条数据在数据库中的主键System.out.println(admin.getId());sqlSession.commit();//手动提交数据库事务管理sqlSession.close();}

 2、修改示例

1、定义修改接口

package com.ffyc.mybatispro.dao;import com.ffyc.mybatispro.model.Admin;
import org.apache.ibatis.annotations.Param;import java.util.List;public interface AdminDao {/*对象传参数*/void updateAdmin(Admin admin);}

2、在sql映射文件中写sql语句

   <update id="updateAdmin" parameterType="Admin">update admin set account=#{account},password=#{password} where id=#{id}</update>

3、单元测试

    public void update(){System.out.println("修改");Reader reader= Resources.getResourceAsReader("mybatis.xml");//2.创建SqlSessionFactorySqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);//SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁//3.创建 SqlSessionSqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话AdminDao adminDao=sqlSession.getMapper(AdminDao.class);Admin admin=new Admin();admin.setId(3);admin.setAccount("ccc");admin.setPassword("666");admin.setGender("男");adminDao.updateAdmin(admin);sqlSession.commit();sqlSession.close();}

执行结果

 

删除示例

1、定义删除接口

package com.ffyc.mybatispro.dao;import com.ffyc.mybatispro.model.Admin;
import org.apache.ibatis.annotations.Param;import java.util.List;public interface AdminDao {/*一个值传参数*/void deleteAdmin(int id);}

2、在sql映射文件中写sql语句

    <delete id="deleteAdmin" parameterType="int">delete from admin where id = #{id}</delete>

3、单元测试

   @Testpublic void delete(){System.out.println("删除");PUblic static void main(String[] args) throws IOException {//1.mybatis读取配置文件Reader reader= Resources.getResourceAsReader("mybatis.xml");//2.创建SqlSessionFactorySqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);//SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁//3.创建 SqlSessionSqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话AdminDao adminDao=sqlSession.getMapper(AdminDao.class);adminDao.deleteAdmin(3);sqlSession.commit();sqlSession.close();}

执行结果

删除了id=3的一行

七、🐦🐦🐦MybatisX:

 mybatis的一个小插件可以快速帮助我们使用sql映射文件和接口

点击旁边的小鸟会快速的转换到相应的sql映射文件或者时接口

这篇关于mybatis框架搭建、mybatis打印日志设置、参数传递使用、myatis插件MyBatisX的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1107280

相关文章

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3