10.29第一个Mybatis程序

10.29第一个Mybatis程序

步骤

  1. 新建Maven工程

  2. 配置pom.xml文件

  3. 新建项目层级目录

  4. 书写配置文件

配置pom.xml文件

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 <modelVersion>4.0.0</modelVersion>

 <groupId>org.example</groupId>
 <artifactId>MybatisStudy</artifactId>
 <version>1.0-SNAPSHOT</version>
 <packaging>war</packaging>

 <name>MybatisStudy</name>
 <!-- FIXME change it to the project's website -->
 <url>http://www.mybatisstudy.com</url>

 <properties>
   <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
   <maven.compiler.source>1.7</maven.compiler.source>
   <maven.compiler.target>1.7</maven.compiler.target>
 </properties>

 <dependencies>
   <!--单元测试的junit-->
   <dependency>
     <groupId>junit</groupId>
     <artifactId>junit</artifactId>
     <version>4.11</version>
     <scope>test</scope>
   </dependency>

   <!--导入testng-->
   <dependency>
     <groupId>org.testng</groupId>
     <artifactId>testng</artifactId>
     <version>7.1.0</version>
   </dependency>

   <!--导入mysql驱动-->
   <dependency>
     <groupId>mysql</groupId>
     <artifactId>mysql-connector-java</artifactId>
     <version>8.0.19</version>
   </dependency>

   <!--导入mybatis-->
   <dependency>
     <groupId>org.mybatis</groupId>
     <artifactId>mybatis</artifactId>
     <version>3.5.5</version>
   </dependency>

   <!--导入log4j依赖-->
   <dependency>
     <groupId>com.att.inno</groupId>
     <artifactId>log4j</artifactId>
     <version>1.2.13</version>
   </dependency>
 </dependencies>

 <build>
   <finalName>MybatisStudy</finalName>
   <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
     <plugins>
       <plugin>
         <artifactId>maven-clean-plugin</artifactId>
         <version>3.1.0</version>
       </plugin>
       <!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
       <plugin>
         <artifactId>maven-resources-plugin</artifactId>
         <version>3.0.2</version>
       </plugin>
       <plugin>
         <artifactId>maven-compiler-plugin</artifactId>
         <version>3.8.0</version>
       </plugin>
       <plugin>
         <artifactId>maven-surefire-plugin</artifactId>
         <version>2.22.1</version>
       </plugin>
       <plugin>
         <artifactId>maven-war-plugin</artifactId>
         <version>3.2.2</version>
       </plugin>
       <plugin>
         <artifactId>maven-install-plugin</artifactId>
         <version>2.5.2</version>
       </plugin>
       <plugin>
         <artifactId>maven-deploy-plugin</artifactId>
         <version>2.8.2</version>
       </plugin>
     </plugins>
   </pluginManagement>
 </build>
</project>

新建项目层级目录

/MybatisStudy
/idea
/src
/main
/java
/com
/junkingboy
/bean
/mapper
/properties
/resources
/webapp
/WEB-INF

书写配置文件

日志配置文件:--->properties目录下

# logging configuration
log4j.rootLogger=ERROR,stdout
# Mybatis logging configuration
log4j.logger.com.junkingboy=DEBUG
# 控制台输出
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p[%t] - %m%n

在日志文件中配置了全局的日志配置、MyBatis 的日志配置和控制台输出,其中 MyBatis 的日志配置用于将 com.junkingboy 包下所有类的日志记录级别设置为 DEBUG

配置WebsiteMapper.xml文件:

<?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="com.junkingboy.mapper.WebsiteMapper">
   <!--添加一个网站信息-->
   <insert id="addWebsite" parameterType="com.junkingboy.bean.Website">
      insert into javawebtest.website(name, url, age, country) values(#{name}, #{url}, #{age}, #{country});
   </insert>
   
   <!--查询所有网站的信息-->
   <select id="selectAllWebsite" resultType="com.junkingboy.bean.Website">
      select * from javawebtest.website;
   </select>
</mapper>

标签说明:

  • <mapper> 元素是配置文件的根元素,它包含了namespace属性,该属性值通常设置为“包名+SQL映射文件名”,用于指定唯一的命名空间。

  • <select><insert> 中的信息用于执行查询、添加操作

  • “#{}”表示一个占位符,相当于“?”,而“#{name}”表示该占位符待接收参数的名称为name

Mybatis核心配置文件:

<?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">
<configuration>
   <!--设置日志实现类-->
   <settings>
       <setting name="logImpl" value="LOG4J"/>
   </settings>

   <!--配置mybatis的运行环境-->
   <environments default="test">
       <environment id="test">
           <!--使用JDBC的事务管理-->
           <transactionManager type="JDBC" />
           <dataSource type="POOLED">
               <!--配置mysql数据库的驱动-->
               <!--配置驱动-->
               <property name="driver" value="com.mysql.jdbc.Driver" />
               <!--连接url-->
               <property name="url" value="jdbc:mysql://localhost:3306/javawebtest?characterEncoding=utf-8"/>
               <!--配置用户名和密码-->
               <property name="username" value="root"/>
               <property name="password" value="root"/>
           </dataSource>
       </environment>
   </environments>

   <!--将mapper文件加入到配置文件中-->
   <mappers>
       <mapper resource="com/junkingboy/mapper/WebsiteMapper.xml" />
   </mappers>
</configuration>

特点:

该文件配置在resources目录下

为了方便在框架集成时更好地区分各个配置文件,一般将此文件名命名·“mybatis-config.xml”·,该文件用于配置数据库连接信息和 MyBatis 的参数。

创建测试类:

步骤:

  • 输入流读取配置文件

  • 根据配置信息构建SqlSessionFactory对象

  • 通过SqlSessionFactory对象创建SqlSession对象

  • 使用SqlSesion对象的方法执行对数据库的操作

实体类:

package com.junkingboy.test;

import com.junkingboy.bean.Website;
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 java.io.IOException;
import java.io.InputStream;
import java.util.List;

/**
* @description:测试Mybatis
* @data: 2021/10/29 17:53
* @author: Lucifer
*/
public class TestWebsite {
   public static void main(String[] args) throws IOException {
       /*
       步骤:
       - 输入流读取配置文件
       - 根据配置信息构建`SqlSessionFactory`对象
       - 通过`SqlSessionFactory`对象创建`SqlSession`对象
       - 使用`SqlSesion`对象的方法执行对数据库的操作
        */
       //io流读取配置文件
       InputStream config = Resources.getResourceAsStream("mybatis-config.xml");
       //根据配置文件构建SqlSessionFactory对象
       //SqlSessionFactoryBuilder是SqlSessionFactory接口的实现类,提供了创建对象的方法
       SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(config);
       //通过SqlSessionFactory对象创建SqlSession对象
       SqlSession ss = ssf.openSession();
       /*SqlSession执行文件中定义的SQL,并返回映射结果*/

       //添加网站--->创建Website的bean对象
       Website website = new Website();
       website.setName("帅气俊!");
       website.setUrl("http://localhost/");
       website.setAge(22);
       website.setCountry("CN");

       //使用SqlSession下的方法执行插入操作
       /*
       传参:
       - xml中定义的属性名称
       - 需要插入的对象
        */
       ss.insert("com.junkingboy.mapper.WebsiteMapper.addWebsite", website);

       //查看所有的网站--->封装成一个list对象
       List<Website> listWeb = ss.selectList("com.juningboy.mapper.WebsiteMapper.selectAllWebsite");
       //读取list内容
       listWeb.forEach(System.out::println);

       //提交事务
       ss.commit();
       //关闭SqlSession连接
       ss.close();
  }
}

原文地址:https://www.cnblogs.com/JunkingBoy/p/15497474.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


本篇文章和大家了解一下怎么搭建maven私有仓库。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。在本篇文章中,我们将介绍如何搭建一个Maven...
今天小编给大家分享的是如何解决Maven依赖冲突,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。目...
这篇文章主要介绍了Maven仓库分类的优先级是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Maven仓库分类的优先级是什么文...
本篇内容主要讲解“Maven怎么实现自己的starter依赖”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Maven怎
本篇内容主要讲解“maven不能下载oraclejdbc驱动的问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大...
这篇文章主要介绍了怎么使用maven基本命令打包包名的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用maven基本命令打包包...
本篇内容介绍了“maven中profile如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧...
本文小编为大家详细介绍“Maven打包没有指定主类问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Maven打包没有指定主类问题怎么解决”文章能帮助...
这篇文章主要介绍“maven怎么打包动态环境变量”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“maven怎么打包动态环...
今天小编给大家分享一下Maven离线模式打包的步骤是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考
本文小编为大家详细介绍“maven打包时候修改包名称带上git版本号和打包时间的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“maven打包时候修改包...
这篇文章主要讲解了“maven打包怎么指定jdk的版本”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“maven打...
这篇“Maven打包时怎么指定启动类”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读
这篇文章主要讲解了“怎么使用jenkins配置maven和JDK”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎
这篇文章主要介绍了maven中配置项目的jdk版本无效怎么排查的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇maven中配置项目的jdk...
今天小编给大家分享一下Maven提示jdk版本不正确怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考
本篇内容主要讲解“maven优缺点及使用方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“maven优缺点
这篇文章主要介绍“maven项目引入maven库没有jar怎么处理”,在日常操作中,相信很多人在maven项目引入maven库没有jar怎么处理问题上存在疑惑,小编查阅了各式资...
本篇内容主要讲解“怎么下载远程maven仓库的jar并手动放到本地仓库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学...
这篇文章主要介绍“maven私服搭建与使用的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“maven私服搭建...