我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Mybatis(一):环境搭建

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Mybatis(一):环境搭建

Mybatis(一):环境搭建



前言

本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主!也许一个人独行,可以走的很快,但是一群人结伴而行,才能走的更远!

一、MyBatis简介

1、MyBatis历史

MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下,iBatis3.x正式更名为MyBatis。代码于2013年11月迁移到Github

iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。 iBatis提供的持久层框架包括SQL MapsData Access Objects(DAO)。

2、MyBatis特性

MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架
MyBatis 避免了几乎所有的 JDBC代码和手动设置参数以及获取结果集
MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和JavaPOJOPlain Old Java Objects,普通的Java对象)映射成数据库中的记录
MyBatis 是一个 半自动的ORMObjectRelation Mapping)框架

3、MyBatis下载

点击跳转下载页面
在这里插入图片描述

4、和其它持久化层技术对比

JDBC

SQL 夹杂在Java代码中耦合度高,导致硬编码内伤
● 维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见
● 代码冗长,开发效率低

HibernateJPA
● 操作简便,开发效率高
● 程序中的长难复杂 SQL 需要绕过框架
● 内部自动生产的 SQL,不容易做特殊优化
● 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难
● 反射操作太多,导致数据库性能下降

MyBatis

●轻量级,性能出色 SQLJava 编码分开,功能边界清晰
Java代码专注业务、SQL语句专注数据
●开发效率稍逊于HIbernate,但是完全能够接受

二、搭建MyBatis

1、开发环境

IDEAidea 2019.2
⭕ 构建工具:maven 3.5.4
MySQL版本:MySQL 5.7
MyBatis版本:MyBatis 3.5.7

2、创建maven工程

2.1 打包方式:jar

2.2 引入依赖

<dependencies>    <dependency>    <groupId>org.mybatisgroupId>    <artifactId>mybatisartifactId>    <version>3.5.7version>  dependency>     <dependency>    <groupId>junitgroupId>    <artifactId>junitartifactId>    <version>4.12version>    <scope>testscope>  dependency>     <dependency>    <groupId>mysqlgroupId>    <artifactId>mysql-connector-javaartifactId>    <version>5.1.3version>  dependency>dependencies>

3、创建MyBatis的核心配置文件

⭕ 习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。
⭕ 将来整合Spring之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。
⭕ 核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息

mybatis-config.xml:

DOCTYPE configuration    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"    "http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration>    <environments default="development">    <environment id="development">      <transactionManager type="JDBC"/>      <dataSource type="POOLED">        <property name="driver" value="com.mysql.jdbc.Driver"/>        <property name="url" value="jdbc:mysql://localhost:3306/MyBatis"/>        <property name="username" value="root"/>        <property name="password" value="0523"/>      dataSource>    environment>  environments>      <mappers>    <mapper resource="mappers/UserMapper.xml"/>  mappers>configuration>

4、创建mapper接口

MyBatis中的mapper接口相当于以前的dao,我们可以理解为与之前我们学习的DAO类相呼应。但是区别在于,mapper仅仅是接口,我们不需要提供它的实现类。

public interface UserMapper {    int insertUser();}

5、创建MyBatis的映射文件

⭕ 相关概念:ORM(Object Relationship Mapping)对象关系映射。
● 对象:Java的实体类对象
● 关系:关系型数据库
● 映射:二者之间的对应关系

⭕ 一张数据库的表对应一个DAO类,即一张表对应一个Mapper接口,一个Mapper接口对应一个映射文件,所有有此对应关系:
一张数据库表<===>一个实体类<===>一个DAO/Mapper接口<===>一个映射文件

Java概念数据库概念
属性字段/列
对象记录/行

⭕ 映射文件的命名规则: 表所对应的实体类的类名+Mapper.xml
例如:表t_user,映射的实体类为User,所对应的映射文件为UserMapper.xml
因此一个映射文件对应一个实体类,对应一张表的操作

MyBatis映射文件用于编写SQL,访问以及操作表中的数据

MyBatis映射文件存放的位置是class="lazy" data-src/main/resources/mappers目录下

MyBatis中可以面向接口操作数据,要保证两个一致:
mapper接口的全类名和映射文件的命名空间(namespace)保持一致
mapper接口中方法的方法名和映射文件中编写SQL的标签的id属性保持一致

User类:

public class User {    private Integer id;    private String username;    private String password;    private Integer age;    private String sex;    private String email;    ...}

UserMapper.java

public interface UserMapper {            int insertUser();}

UserMapper.xml:

DOCTYPE mapper            PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"            "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.ir.mybatis.mapper.UserMapper">                    <insert id="insertUser">                insert into t_user values(null,'张三','123',23,'女')          insert>          mapper>

6、通过junit测试功能

测试:

package com.ir.mybaits.test;import com.ir.mybatis.mapper.UserMapper;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Test;import java.io.IOException;import java.io.InputStream;public class MyBatisTest {    @Test    public void testMyBatis() throws IOException {        //加载核心配置文件---->制作建筑图纸        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");        //获取SqlSessionFactoryBuilder---->招募工人        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();        //通过核心配置文件所对应的字节输入流创建工厂类SqlSessionFactory,生产SqlSession对象---->图纸给工人,去造工厂        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);        //创建SqlSession对象,此时通过SqlSession对象所操作的sql都必须手动提交或回滚事务---->工厂生产出产品        SqlSession sqlSession = sqlSessionFactory.openSession();        //调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配元素文件,通过调用的方法名匹配映射文件中的SQL标签,并执行标签中的SQL语句---->产品的功能        UserMapper mapper = sqlSession.getMapper(UserMapper.class);        //测试        int result = mapper.insertUser();        //提交事务        sqlSession.commit();        System.out.println("result:"+result);    }}

知识点:

SqlSession:代表Java程序和数据库之间的会话。(HttpSessionJava程序和浏览器之间的会话)

SqlSessionFactory:是“生产”SqlSession的“工厂”。

⭕工厂模式:如果创建某一个对象,使用的过程基本固定,那么我们就可以把创建这个对象的相关代码封装到一个“工厂类”中,以后都使用这个工厂类来“生产”我们需要的对象。

7、优化

7.1 优化一:自动提交事务

SqlSession默认不自动提交事务,若需要自动提交事务,可以使用SqlSessionFactory.openSession(true);

7.2 优化二:加入log4j日志功能

(1)加入依赖

<dependency>  <groupId>log4jgroupId>  <artifactId>log4jartifactId>  <version>1.2.17version>dependency>

(2)加入log4j的配置文件

log4j的配置文件名为log4j.xml,存放的位置是class="lazy" data-src/main/resources目录下

⭕日志的级别:FATAL(致命)>ERROR(错误)>WARN(警告)>INFO(信息)>DEBUG(调试)
从左到右打印的内容越来越详细

log4j.xml

DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">   <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">    <param name="Encoding" value="UTF-8" />    <layout class="org.apache.log4j.PatternLayout">      <param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS}%m (%F:%L) \n" />    layout>  appender>  <logger name="java.sql">    <level value="debug" />  logger>  <logger name="org.apache.ibatis">    <level value="info" />  logger>  <root>    <level value="debug" />    <appender-ref ref="STDOUT" />  root>log4j:configuration>

三、核心配置文件详解

jdbc.properties

jdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://localhost:3306/mybatisjdbc.username=rootjdbc.password=0523   

mybatis-config.xml

DOCTYPE configuration        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"        "http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration>                        <properties resource="jdbc.properties" />                <typeAliases>                                                                <package name="com.ir.mybatis.pojo"/>        typeAliases>                <environments default="development">                                <environment id="development">                                                <transactionManager type="JDBC"/>                                                <dataSource type="POOLED">        <property name="driver" value="${jdbc.driver}"/>        <property name="url" value="${jdbc.url}"/>        <property name="username" value="${jdbc.username}"/>        <property name="password" value="${jdbc.password}"/>                        dataSource>                environment>                <environment id="test">                        <transactionManager type="JDBC"/>                        <dataSource type="POOLED">    <property name="driver" value="com.mysql.jdbc.Driver"/>    <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>    <property name="username" value="root"/>    <property name="password" value="123456"/>                        dataSource>                environment>        environments>                <mappers>                                                <package name="com.ir.mybatis.mapper"/>        mappers>configuration>

注意:

⭕ 核心配置文件中的标签必须按照固定的顺序:

  1. properties
  2. settings
  3. typeAliases
  4. typeHandlers
  5. objectFactory
  6. objectWrapperFactory
  7. reflectorFactory
  8. plugins
  9. environments
  10. databaseIdProvider
  11. mappers

支持以包为单位来设置默认类型

● 支持以包为单位来引入映射文件
● 在resources下创建包名时,由于resources下为普通文件,所以并不可以以".“为分隔符的方式来创建嵌套的包名,而应该用以”/"的方式来创建

在这里插入图片描述

四、idea中设置文件模板

1、在idea中设置核心配置文件的模板

mybatis-config官方文档模板:

DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration>    <environments default="development">        <environment id="development">            <transactionManager type="JDBC"/>            <dataSource type="POOLED">                <property name="driver" value="${driver}"/>                <property name="url" value="${url}"/>                <property name="username" value="${username}"/>                <property name="password" value="${password}"/>            dataSource>        environment>    environments>        <mappers>        <mapper resource="org/mybatis/example/BlogMapper.xml"/>    mappers>    configuration>

⭕ 设置:

在这里插入图片描述

2、在idea中设置映射文件的模板

mybatis-mapper官方文档模板:

DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="org.mybatis.example.BlogMapper">    <select id="selectBlog" resultType="Blog">        select * from Blog where id = #{id}    select>mapper>

⭕ 设置:
在这里插入图片描述
在这里插入图片描述

来源地址:https://blog.csdn.net/weixin_52533007/article/details/125620656

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Mybatis(一):环境搭建

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何搭建Mybatis环境

这篇文章主要介绍如何搭建Mybatis环境,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Mybatis的简介:  MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache sof
2023-05-30

idea怎么搭建mybatis环境

要在IntelliJ IDEA中搭建MyBatis环境,请按照以下步骤进行操作:1. 在IntelliJ IDEA中创建一个新的Java项目。2. 打开项目设置(File -> Project Structure)。3. 在左侧面板中,选择
2023-10-10

使用Spring如何搭建一个SpringMVC与MyBatis环境

这篇文章将为大家详细讲解有关使用Spring如何搭建一个SpringMVC与MyBatis环境,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.对原生态jdbc程序中问题总结1.1 jdbc
2023-05-31

MyBatis 环境搭建配置全过程【IDEA】

文章目录 一、MyBatis 介绍二、MyBatis 环境搭建1.MyBatis 下载2.配置 jdk 版本3.创建 Maven 工程4.IDEA 连接数据库5.项目文件构架6.引入相关依赖7.命令行创建数据库8.数据库配置文件9.
2023-08-17

怎么在Mybatis中搭建动态SQL环境

今天就跟大家聊聊有关怎么在Mybatis中搭建动态SQL环境,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. Mybatis–动态SQL动态 SQL 是 MyBatis 的强大特性
2023-06-14

使用SpringMVC和MyBatis框架如何搭建一个开发环境

本篇文章给大家分享的是有关使用SpringMVC和MyBatis框架如何搭建一个开发环境,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、下载SpringMVC框架架包,点击打
2023-05-31

python3环境搭建

安装依赖环境yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel
2023-01-30

01-环境搭建

MTVmodel:模型负责业务数据对象与数据库对象template:模板,负责展示数据view:视图,负责业务逻辑MVCmodel:模型负责业务数据对象与数据库对象view:视图,负责与用户交互的页面controller:控制器,接收用户的
2023-01-31

Python3 环境搭建

Python3 环境搭建  这里介绍在windows、Linux(CentOS7)两个平台上,python开发环境的搭建方法  主要使用miniconda作为python的开发,测试环境一、windows平台上的python环境搭建  1、
2023-01-31

flutter 环境搭建

一、简介 Flutter 是谷歌开发的一款开源、免费的,基于 Dart 语言的U1框架,可以快速在i0S和Android上构建高质量的原生应用。 它最大的特点就是跨平台和高性能。Dart是由谷歌,在2011 年开发的计算机编程语言,它可以被
2023-08-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录