1. 开发环境

  • IDE:IDEA

  • 构建工具:maven4.0.0

  • MySQL版本:8.0.11、

    记得创建好数据库

  • Mybatis版本:3.5.7

MySQL不同版本的注意事项

  1. 驱动类driver-class-name

    • MySQL 5版本使用jdbc5驱动,驱动类使用:com.mysql.jdbc.Driver

    • MySQL 8版本使用jdbc8驱动,驱动类使用:com.mysql.cj.jdbc.Driver

  2. 连接地址url(下面url中ssm是我的数据库名,记得更改)

    • MySQL 5版本的url:jdbc:mysql://localhost:3306/ssm

    • MySQL 8版本的url:jdbc:mysql://localhost:3306/ssm?useSSL=false

      useSSL=false:不使用安全连接方式。我是不加的话会报错,看情况加了

    注意:localhost也可以换成自己数据库IP地址,像120.77.92.117

2. 创建maven工程

可以先跳到总结看看整个项目目录和代码的执行过程,先大概了解每个文件。

以下代码都写在配置文件pom.xml中。

  1. 打包方式:jar

    <packaging>jar</packaging> <!--打包方式:jar包-->
  2. 引入依赖

    <dependencies>
    <!--mybatis 依赖-->
    <dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.10</version>
    </dependency> <!--mysql 驱动-->
    <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.11</version>
    </dependency> <!--junit 单元测试-->
    <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.13.1</version>
    <scope>test</scope>
    </dependency>
    </dependencies>

3.创建实体类:

数据库t_user表字段:

User类中的属性与数据库中对应,记得写上构造方法与get、set方法。

4. 创建Mybatis的核心配置文件

  • 习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。

  • 核心配置文件存放的位置是src/main/resources目录下

  • 核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息

那么mybatis-config.xml要怎么写呢?? 官网给了我们一个简单示例。

这是我的配置代码:

5. 创建mapper接口

接口起名规则:实体类的类名+Mapper

6. 创建Mybatis的映射文件

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

相关概念:ORM(Object Relationship Mapping)对象关系映射。

  • 对象:Java的实体类对象

  • 关系:关系型数据库

  • 映射:二者之间的对应关系

  1. 映射文件的命名规则:

    表所对应的实体类的类名+Mapper.xml。一般与mapper接口同名

    例如:表t_user,映射的实体类为User,所对应的映射文件为UserMapper.xml

  2. 因此一个映射文件对应一个实体类,对应一张表的操作

  3. MyBatis映射文件存放的位置是src/main/resources/mappers目录下

  4. MyBatis中可以面向接口操作数据,要保证两个一致:

  • mapper接口的全类名和映射文件的命名空间(namespace)保持一致

  • mapper接口中方法的方法名和映射文件中编写SQL的标签的id属性保持一致

不太理解两个一致的,没关系,后面总结时再具体解释说明一下

<?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.atguigu.mybatis.mapper.UserMapper">
<insert id="insertUser">
insert into t_user values(null,'admin','123456',23,'男','12345@qq.com')
</insert>
</mapper>

不要忘了,我们前面在配置核心时mybatis-config.xml没有引入Mybatis映射文件。现在我们已经创建了映射文件,所以要补充上

7.运行结果


8. 总结

使用Mybatis实现简单的数据库插入操作,我们要编写的只有这6个文件:

我们看看插入操作时,代码执行的主要过程是什么样的:

还记得映射文件中两个一致吗??

  • mapper接口的全类名和映射文件的命名空间(namespace)保持一致

  • mapper接口中方法的方法名和映射文件中编写sql的标签的id属性保持一致

看到执行过程后,应该明白了吧。

部分内容来自 B站尚硅谷课程 。老师讲得很好,有兴趣的可以听听。

Mybatis简单入门--插入数据的更多相关文章

  1. mybatis foreach批量插入数据:Oracle与MySQL区别

    mybatis foreach批量插入数据:Oracle与MySQL不同点: 主要不同点在于foreach标签内separator属性的设置问题: separator设置为","分 ...

  2. mybatis简单入门介绍

    mybatis入门 简介 什么是mybatis? MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及 ...

  3. myBatis获取批量插入数据的主键id

    在myBatis中获取刚刚插入的数据的主键id是比较容易的 , 一般来说下面的一句话就可以搞定了 , 网上也有很多相关资料去查. @Options(useGeneratedKeys = true, k ...

  4. MyBatis中批量插入数据对插入记录数的限制

    <基于Mybatis框架的批量数据插入的性能问题的探讨>(作者:魏静敏 刘欢杰 来源:<计算机光盘软件与应用> 2013 年第 19 期)中提到批量插入的记录数不能超过1000 ...

  5. mybatis+Oracle 批量插入数据,有数据做更新操作

    <!-- 批量添加 -->     <insert id="batchAdd" parameterType="java.util.List"& ...

  6. Mybatis简单入门

    MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的XML或注解用 ...

  7. mybatis向数据库插入数据 (传入的是一个实体类)

    /** * 插入用户信息 user为实体类 * @param user */ public int insert( User user); //实体类不用@param标注 //mybatis的xml文 ...

  8. MyBatis 简单入门

    添加maven 依赖 <dependencies> <dependency> <groupId>org.mybatis</groupId> <ar ...

  9. Java通过Mybatis实现批量插入数据到Oracle中

    <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "- ...

随机推荐

  1. salesforce零基础学习(一百一十五)记一个有趣的bug

    本篇参考:https://help.salesforce.com/s/articleView?language=en_US&type=1&id=000319486 page layou ...

  2. 轻松解决pycharm中游标变宽的问题

    所谓的知者易,惑者难,一招回到解放前,遇到下面这种问题的解决方法: 轻轻动动你那可爱的手指头点击一下 insert插入键便可以轻松切换到你想要的游标了,不要感谢哥,哥也只是个过客

  3. Java-SpringBoot-使用多态给项目解耦

    Java-SpringBoot-使用多态给项目解耦 提及 今天在打算维护一下智慧社区这个项目的时候,想到项目是使用Satoken这个开箱即用的授权和认证的组件,因为在项目开启的时候对SpringSec ...

  4. 菜鸟学git的基本命令及常见错误

    Git init //在当前项目工程下履行这个号令相当于把当前项目git化,变身!\ git config --global user.name "xxx" # 配置用户名 git ...

  5. DAST 黑盒漏洞扫描器 第三篇:无害化

    0X01 前言 甲方扫描器其中一个很重要的功能重点,就是无害化,目的是尽量降低业务影响到可接受程度. 做过甲方扫描器,基本上对于反馈都有所熟悉. "我们的服务有大量报错,请问和你们有关么&q ...

  6. QT5 QSS QML界面美化视频课程系列 QT原理 项目实战 C++1X STL

    QT5 QSS QML界面美化视频课程系列 QT原理 项目实战 C++1X STL 课程1   C语言程序设计高级实用速成课程 基础+进阶+自学 课程2   C语言程序设计Windows GDI图形绘 ...

  7. 在C#开发中使用第三方组件LambdaParser、DynamicExpresso、Z.Expressions,实现动态解析/求值字符串表达式

    在进行项目开发的时候,刚好需要用到对字符串表达式进行求值的处理场景,因此寻找了几个符合要求的第三方组件LambdaParser.DynamicExpresso.Z.Expressions,它们各自功能 ...

  8. 强化学习-Windows安装gym、atari和box2d环境

    安装gym pip3 install gym pip3 install gym[accept-rom-license] 安装atari环境[可选] 下载安装VS build tools 如果出现 OS ...

  9. vue按需引入第三方ui插件优化

    components.js import { fullScreenContainer, borderBox12, scrollBoard, loading, borderBox10, borderBo ...

  10. C#中的 Attribute 与 Python/TypeScript 中的装饰器是同个东西吗

    前言 最近成功把「前端带师」带入C#的坑(实际是前端带师开始从cocos转unity游戏开发了) 某天,「前端带师」看到这段代码后问了个问题:[这个是装饰器]? [HttpGet] public Re ...