springboot整合mybatis笔记

摘要:
1首先创建一个springboot项目创建项目的文件结构以及jdk的版本选择项目所需要的依赖之后点击finish,完成创建2以下是文件结构看一下啊pom.xml;˂?

1首先创建一个springboot项目

springboot整合mybatis笔记第1张

创建项目的文件结构以及jdk的版本

springboot整合mybatis笔记第2张

选择项目所需要的依赖

springboot整合mybatis笔记第3张

springboot整合mybatis笔记第4张

之后点击finish,完成创建

2以下是文件结构

springboot整合mybatis笔记第5张

看一下啊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>com.example</groupId>
    <artifactId>demo-mybatis</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>demo-mybatis</name>
    <description>Demo project for Spring Boot</description>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.6.RELEASE</version>
        <relativePath/> <!--lookup parent from repository -->
    </parent>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <!--mybatis generator 自动生成代码插件 -->
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <configuration>
                    <configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
                    <overwrite>true</overwrite>
                    <verbose>true</verbose>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

3项目不使用application.properties文件 而使用更加简洁的application.yml文件:
将原有的resource文件夹下的application.properties文件删除,创建一个新的application.yml配置文件,
文件的内容如下:

注意:mapper-locations: classpath:mapping/*.xml #注意:一定要对应mapper映射xml文件的所在路径
type-aliases-package: com.winter.model # 注意:对应实体类的路径

如果在代码中注释之后报错,建议删掉注释,本人被这个问题折腾的挺难受

server:
  port: 8080
spring:
    datasource:
        name: test
        url: jdbc:mysql://127.0.0.1:3306/test
        username: root
        password: 123456
    mvc:
        view:
            prefix: /
            suffix: .html
mybatis:
mapper-locations: classpath:mapping/*.xml
type-aliases-package: com.winter.model

4接下去在数据库里建立一张简单的表作为实验,这里就不写建表的操作了。

5使用mybatis generator 自动生成代码:

配置pom.xml中generator 插件所对应的配置文件 ${basedir}/src/main/resources/generator/generatorConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
    <!--数据库驱动:选择你的本地硬盘上面的数据库驱动包-->
    <classPathEntry  location="D:maven_Repositorymysqlmysql-connector-java5.1.34"/>
    <context id="DB2Tables"targetRuntime="MyBatis3">
        <commentGenerator>
            <property name="suppressDate"value="true"/>
            <!--是否去除自动生成的注释 true:是 : false:否 -->
            <property name="suppressAllComments"value="true"/>
        </commentGenerator>
        <!--数据库链接URL,用户名、密码 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"connectionURL="jdbc:mysql://127.0.0.1/test"userId="root"password="212517">
        </jdbcConnection>
        <javaTypeResolver>
            <property name="forceBigDecimals"value="false"/>
        </javaTypeResolver>
        <!--生成模型的包名和位置-->
        <javaModelGenerator targetPackage="com.example.demomybatis.model"targetProject="src/main/java">
            <property name="enableSubPackages"value="true"/>
            <property name="trimStrings"value="true"/>
        </javaModelGenerator>
        <!--生成映射文件的包名和位置-->
        <sqlMapGenerator targetPackage="mapping"targetProject="src/main/resources">
            <property name="enableSubPackages"value="true"/>
        </sqlMapGenerator>
        <!--生成DAO的包名和位置-->
        <javaClientGenerator type="XMLMAPPER"targetPackage="com.example.demomybatis.mapper"targetProject="src/main/java">
            <property name="enableSubPackages"value="true"/>
        </javaClientGenerator>
        <!--要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名-->
        <table tableName="stu_info"domainObjectName="User"enableCountByExample="true"enableUpdateByExample="true"enableDeleteByExample="false"enableSelectByExample="false"selectByExampleQueryId="false"></table>
    </context>
</generatorConfiguration>

点击run-Edit Configurations

springboot整合mybatis笔记第6张

添加配置

springboot整合mybatis笔记第7张

运行(注意!!!同一张表一定不要运行多次,因为mapper的映射文件中会生成多次的代码,导致报错,切记

springboot整合mybatis笔记第8张

最后生成的文件以及结构

springboot整合mybatis笔记第9张

6打开类DemoMybatisApplication.java,这个是springboot的启动类。我们需要添加点东西:

springboot整合mybatis笔记第10张

7最后写好controller,service层代码就可以测试了

UserController.java

springboot整合mybatis笔记第11张

UserService.java

springboot整合mybatis笔记第12张

UserServiceImpl.java

package com.example.demomybatis.service.impl;
import com.example.demomybatis.mapper.UserMapper;
import com.example.demomybatis.model.User;
import com.example.demomybatis.model.UserExample;
import com.example.demomybatis.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public List<User> selectAll() {
return userMapper.selectAll();
}

}

之后就可以运行测试了。

参考文章:https://blog.csdn.net/winter_chen001/article/details/77249029#commentBox

免责声明:文章转载自《springboot整合mybatis笔记》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇透彻详细电荷泵升压电路的工作原理分析(配Multisim仿真验证)HP11.31安装11.2.0.3实施手册下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

[JavaWeb]SpringSecurity-OAuth2.0 统一认证、资源分离的配置,用于分布式架构、模块化开发的认证体系

前言 关于 OAuth2.0的认证体系,翻阅了好多资料,RCF 文档太多,看了一半就看不下去了,毕竟全英文的文档看起来,是有一点让我烦躁,但也对 OAuth2.0的认证流程有了一个基本的概念,之前用 SpringSecurity 做了一个基于 RBAC 的权限管理系统的基础配置,所以对 SpringSecurity 算是比较了解了,于是 OAuth2.0...

Mybatis-初识

1、Mybatis整体架构 2、Mybatis启动案例  根据官网介绍官网提供了两个Mybatis启动测试案例(参考:https://mybatis.org/mybatis-3/zh/getting-started.html)  准备资源:    数据库配置及驱动依赖(jdbcDriver、url、username、password)    mybati...

MyBatis:resultMap详解

简介:     MyBatis的每一个查询映射的返回类型都是ResultMap,只是当我们提供的返回类型属性是resultType的时候,MyBatis对自动的给我们把对应的值赋给resultType所指定对象的属性,而当我们提供的返回类型是resultMap的时候,将数据库中列数据复制到对象的相应属性上,可以用于复制查询,两者不能同时用。   resul...

springboot mybatis自定义枚举enum转换

原文链接:https://blog.csdn.net/u014527058/article/details/62883573 一、概述 在利用Spring进行Web后台开发时,经常会遇到枚举类型的绑定问题。一般情况下,如果Spring接收到的参数值为字符串类型,Spring会根据枚举的值与传入的字符串进行对应。假设有如下枚举 清单1:枚举定义 public...

03_mybatis配置文件详解

1. SqlMapConfig.xml mybatis全局配置文件SqlMapConfig.xml,配置内容如下: *properties(属性) setting(全局配置参数) typeAliases(类型别名) typeHandlers(类型处理器) plugins(插件) enviroments(环境集合对象) ​ enviroment(环境子属性对...

MyBatis学习(五)MyBatis-开启log4j日志

1、前言 Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地...