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

Fluent Mybatis有什么用

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Fluent Mybatis有什么用

这篇文章主要介绍Fluent Mybatis有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

一、啥是Fluent-Mybatis

与Mybatis-Plus类似,是对Mybaits进一步的封装,使之语法简洁明了,更重要的是不需要在自主创建Xml文件,可以只用一个实体类对象,通过代码生成器,在编译的过程中生成所需要的各类文件,简化了项目的基础构建,提高开发效率。

Fluent Mybatis有什么用

二、SpringBoot + Fluent-Mybatis

创建数据库测试表

DROP TABLE IF EXISTS `t_user`;create table `t_user`(    id bigint auto_increment comment '主键ID' primary key,    name varchar(30) charset utf8 null comment '姓名',    age int null comment '年龄',    email varchar(50) charset utf8 null comment '邮箱',    gmt_create datetime null comment '记录创建时间',    gmt_modified datetime null comment '记录最后修改时间',    is_deleted tinyint(2) default 0 null comment '逻辑删除标识');

创建一个Springboot项目,pom文件如下

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0</modelVersion>    <parent>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-parent</artifactId>        <version>2.3.1.RELEASE</version>        <relativePath/> <!-- lookup parent from repository -->    </parent>    <groupId>com.mybatis.fluent</groupId>    <artifactId>fluent_mybatis</artifactId>    <version>0.0.1-SNAPSHOT</version>    <name>fluent_mybatis</name>    <description>Demo project for Spring Boot</description>    <properties>        <java.version>1.8</java.version>        <fluent.mybatis.version>1.5.6</fluent.mybatis.version>    </properties>    <dependencies>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter</artifactId>        </dependency>        <!--JDBC驱动-->        <dependency>            <groupId>mysql</groupId>            <artifactId>mysql-connector-java</artifactId>            <scope>runtime</scope>        </dependency>        <!--Mybatis-->        <dependency>            <groupId>org.mybatis.spring.boot</groupId>            <artifactId>mybatis-spring-boot-starter</artifactId>            <version>2.0.1</version>        </dependency>        <!-- fluent mybatis依赖-->        <dependency>            <groupId>com.github.atool</groupId>            <artifactId>fluent-mybatis</artifactId>            <version>${fluent.mybatis.version}</version>        </dependency>        <dependency>            <groupId>com.github.atool</groupId>            <artifactId>fluent-mybatis-processor</artifactId>            <version>${fluent.mybatis.version}</version>            <scope>provided</scope>        </dependency>        <dependency>            <groupId>org.projectlombok</groupId>            <artifactId>lombok</artifactId>            <optional>true</optional>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>            <scope>test</scope>            <exclusions>                <exclusion>                    <groupId>org.junit.vintage</groupId>                    <artifactId>junit-vintage-engine</artifactId>                </exclusion>            </exclusions>        </dependency>    </dependencies>    <build>        <plugins>            <plugin>                <groupId>org.springframework.boot</groupId>                <artifactId>spring-boot-maven-plugin</artifactId>                <configuration>                    <excludes>                        <exclude>                            <groupId>org.projectlombok</groupId>                            <artifactId>lombok</artifactId>                        </exclude>                    </excludes>                </configuration>            </plugin>        </plugins>    </build></project>

代码生成器

import cn.org.atool.generator.FileGenerator;import cn.org.atool.generator.annotation.Table;import cn.org.atool.generator.annotation.Tables;public class AppEntityGenerator {    public static void main(String[] args) {        FileGenerator.build(Abc.class);    }    @Tables(                        url = "jdbc:mysql://IP:3306/test?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai",             username = "XXXXXX",            password = "XXXXXX",                        basePack = "com.mybatis.fluent.fluent_mybatis",                        class="lazy" data-srcDir = "/class="lazy" data-src/main/java",                        daoDir = "/class="lazy" data-src/main/java",                        gmtCreated = "gmt_create", gmtModified = "gmt_modified", logicDeleted = "is_deleted",                        tables = @Table(value = {"t_user"})    )    static class Abc {    }}

需要注意,默认的是MySQL数据库,如果需要其他数据库,需要手动配置dbType和driver,其他选项按照需要修改。例如oralce

import cn.org.atool.generator.FileGenerator;import cn.org.atool.generator.annotation.Table;import cn.org.atool.generator.annotation.Tables;import cn.org.atool.generator.database.DbType;public class AppEntityGenerator {    public static void main(String[] args) {        FileGenerator.build(Abc.class);    }    @Tables(                        dbType= DbType.ORACLE,            driver= "oracle.jdbc.OracleDriver",            url = "jdbc:oracle:thin:@IP:1521:orcl",            username = "XXXXXX",            password = "XXXXXX",                        basePack = "com.mybatis.fluent.fluent_mybatis",                        class="lazy" data-srcDir = "/class="lazy" data-src/main/java",                        daoDir = "/class="lazy" data-src/main/java",                        gmtCreated = "INSERT_DATE_TIME",                        tables = @Table(value = {"table_name"})    )    static class Abc {    }}

main方法启动执行,生成的项目结构,如果在执行是出现异常

Fluent Mybatis有什么用

需要暂时注释

Fluent Mybatis有什么用

当生成好对应文件,项目目录如下

Fluent Mybatis有什么用

此时TUserDaoImpl会有错误

Fluent Mybatis有什么用

此时将需要将之前注释的provided打开,在执行

Fluent Mybatis有什么用

执行过后,异常消除。此时你就拥有的对数据库此表的强大操作能力。

测试CURD

import cn.org.atool.fluent.mybatis.model.IPagedList;import cn.org.atool.fluent.mybatis.model.StdPagedList;import com.mybatis.fluent.fluent_mybatis.dao.impl.HospitalinfoDaoImpl;import com.mybatis.fluent.fluent_mybatis.dao.impl.TUserDaoImpl;import com.mybatis.fluent.fluent_mybatis.entity.HospitalinfoEntity;import com.mybatis.fluent.fluent_mybatis.entity.TUserEntity;import com.mybatis.fluent.fluent_mybatis.helper.TUserWrapperHelper;import com.mybatis.fluent.fluent_mybatis.wrapper.HospitalinfoQuery;import com.mybatis.fluent.fluent_mybatis.wrapper.TUserQuery;import org.junit.jupiter.api.Test;import org.springframework.boot.test.context.SpringBootTest;import javax.annotation.Resource;import java.io.Serializable;import java.util.List;@SpringBootTestclass FluentMybatisApplicationTests {    @Resource    private TUserDaoImpl dao;    @Test    void add() {        TUserEntity entity = new TUserEntity().setAge(20).setEmail("122@163.com").setName("lisi").setIsDeleted(false);        Serializable id = dao.save(entity);        System.out.println("插入后返回的主键ID为:" + id);    }    @Test    void select(){                TUserQuery query = TUserQuery.query().limit(0,1);        List<TUserEntity> list = dao.listEntity(query);        System.out.println(list);    }    @Test    void upData(){        TUserEntity entity = dao.selectById(1L);        System.out.println(entity);        entity.setAge(2000).setEmail("120098922@qq.com").setName("lisi111").setIsDeleted(true);        System.out.println(entity);        boolean b = dao.updateById(entity);        System.out.println(b);    }    @Test    void delete(){        boolean b = dao.deleteById(1L);        System.out.println(b);        TUserQuery query = TUserQuery.query();        List<TUserEntity> list = dao.listEntity(query);        System.out.println(list);    }}

以上是“Fluent Mybatis有什么用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

免责声明:

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

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

Fluent Mybatis有什么用

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

下载Word文档

猜你喜欢

Fluent Mybatis有什么用

这篇文章主要介绍Fluent Mybatis有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、啥是Fluent-Mybatis与Mybatis-Plus类似,是对Mybaits进一步的封装,使之语法简洁明了,
2023-06-20

Fluent Mybatis中Update语法怎么用

小编给大家分享一下Fluent Mybatis中Update语法怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!数据准备还是用之前在数据库存的数据,数据如下:Update语法简单的写法fm的update简单写法可以直接
2023-06-21

springboot 中怎么整合fluent mybatis

这篇文章给大家介绍springboot 中怎么整合fluent mybatis,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.导入pom依赖
2023-06-20

Fluent MyBatis怎么实现动态SQL

这篇文章主要讲解了“Fluent MyBatis怎么实现动态SQL”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Fluent MyBatis怎么实现动态SQL”吧!目录数据准备代码生成在 W
2023-06-20

Mybatis有什么作用

这篇文章主要为大家展示了“Mybatis有什么作用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Mybatis有什么作用”这篇文章吧。Mybatis 是一个实现了数据持久化的 ORM 框架,简单
2023-06-02

MyBatis Plus有什么用

小编给大家分享一下MyBatis Plus有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!MyBatis Plus 是国内人员开发的 MyBatis 增强工
2023-06-02

Mybatis中PageHelper有什么用

这篇文章主要介绍了Mybatis中PageHelper有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。PageHelper是一款好用的开源免费的Mybatis第三方物理
2023-06-16

mybatis中selectKey有什么用

这篇文章给大家分享的是有关mybatis中selectKey有什么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。mybatis的selectKey作用当我们使用id自增操作Mybatis时,需要返回最新插入的i
2023-06-29

FluentMybatis怎么实现mybatis动态sql拼装和fluent api语法

这篇文章主要讲解了“FluentMybatis怎么实现mybatis动态sql拼装和fluent api语法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“FluentMybatis怎么实现m
2023-06-20

mybatis命名空间有什么用

MyBatis命名空间的作用是用来标识和管理Mapper接口或Mapper XML文件中定义的SQL语句。通过使用命名空间,可以将不同的SQL语句进行分类和封装,提高代码的可维护性和可读性。具体来说,命名空间可以实现以下功能:1. 解决Ma
2023-08-18

MyBatis中SqlSessionFactory和SqlSession有什么用

SqlSessionFactory是MyBatis的核心接口之一,用于创建SqlSession对象。SqlSessionFactory是一个工厂类,负责创建SqlSession对象,并且负责维护数据库连接的生命周期。通常情况下,一个应用只需
MyBatis中SqlSessionFactory和SqlSession有什么用
2024-03-07

mybatis中的trim标签有什么用

MyBatis中的trim标签用于在SQL语句的开头和结尾去除多余的空格,并可以在SQL语句的开头和结尾添加自定义的字符串。trim标签有以下几种使用方式:1. prefixOverrides:指定要删除的前缀字符串,只有当SQL语句以该前
2023-08-09

Mybatis中万能的Map有什么用

这篇文章主要介绍Mybatis中万能的Map有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!万能的Map假设,我们的实体类,或者数据库中的表,字段或者参数过多,我们需要考虑使用Map简单来说,map你用什么参数
2023-06-25

Eclipse的插件MyBatis Editor有什么用

这篇文章将为大家详细讲解有关Eclipse的插件MyBatis Editor有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。MyBatis Editor是一个Eclipse的插件,用来编辑MyBat
2023-06-17

mybatis动态SQL标签有什么作用

MyBatis动态SQL标签用于在SQL语句中添加条件判断和循环操作,根据条件动态生成SQL语句。通过使用动态SQL标签,可以根据不同的条件生成不同的SQL语句,避免在Java代码中拼接SQL语句,提高代码的可读性和维护性。常用的动态SQL
mybatis动态SQL标签有什么作用
2024-04-09

MyBatis中的LogFactory和Log接口有什么用

在MyBatis中,LogFactory是用于创建Log实例的工厂类,而Log接口则是用于记录日志信息的接口。LogFactory负责根据配置文件中指定的日志框架类型(比如log4j、slf4j等)来创建Log实例,然后通过Log实例来记录
MyBatis中的LogFactory和Log接口有什么用
2024-03-08

MyBatis中的#{}和${}有什么区别

这篇文章主要介绍了MyBatis中的#{}和${}有什么区别,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言在MyBatis 的映射配置文件中,动态传递参数有两种方式:1、
2023-06-21

编程热搜

  • 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动态编译

目录