第一个MyBatis查询

简介: 在连接程序与数据库的工具中,我们之前使用的是JDBC技术,但是JDBC的操作流程极为繁琐,因此才有了更优秀框架——MyBatis,下边我们一起来看这个优秀框架MyBatis的操作与使用。

1.什么是MyBatis?


MyBatis是一款优秀的持久层框架,它支持自定义SQL、存储过程以及高级映射。MyBatis去除了几乎所有的JDBC代码以及设置参数和获取结果集的工作。MyBatis可以通过简单的XML或注解来配置和映射原始类型、接口和Java POJO(Plain Old Java Objects,普通老式Java对象)为数据库中的记录。


简单来说,MyBatis是更简单完成程序和数据库交互的工具,也就是更简单的操作和读取数据库的工具。


MyBatis也是一个ORM框架,ORM(Object Relational Mapping),即对象关系映射。在面向对象编程语言中,将关系型数据库中的数据与对象建立起映射关系,进而自动的完成数据与对象的互相转换:


1.将输入数据(即传入对象)+ SQL映射成原生SQL

2.将结果集映射为返回对象,即输出对象


ORM把数据库映射为对象:


数据库表(table) --> 类(class)

记录(record,行数据) -->对象(object)

字段(filed) --> 对象的属性(attribute)

一般的ORM框架,会将数据库模型的每张表都映射为一个Java类。

也就是说使用MyBatis可以像操作对象一样来操作数据库中的表,可以实现对象和数据库表之间的转换,接下来我们来看MyBatis具体该如何使用吧。


2.第一个MyBatis查询


2.1 创建MyBatis项目


2.1.1 创建项目添加相关依赖


此步骤分为两种情况,一种是需要创建新项目,这时直接进行勾选相关依赖即可,而如果是旧项目,直接在pom.xml文件中使用插件添加MyBatis相关依赖即可。


新项目:


微信图片_20230111210823.png

老项目:


微信图片_20230111210820.png

完成相关依赖的添加后,先不要急着启动项目,需要完成下一步配置才能够连接上数据库。


微信图片_20230111210817.png

2.1.2 配置数据库连接字符串和MyBatis(保存的XML目录)


配置数据库连接信息

在开发环境和生产环境都需要进行数据库连接信息的配置。


微信图片_20230111210813.png

配置MyBatis的XML保存路径


在主配置文件中配置运行的环境和MyBatis的XML保存路径


微信图片_20230111210810.png

2.1.3 创建数据库和数据表(用于测试)


-- 创建数据库
drop database if exists mycnblog;
create database mycnblog DEFAULT CHARACTER SET utf8mb4;
-- 使用数据数据
use mycnblog;
-- 创建表[用户表]
drop table if exists  userinfo;
create table userinfo(
    id int primary key auto_increment,
    username varchar(100) not null,
    password varchar(32) not null,
    photo varchar(500) default 'default.png',
    createtime datetime default now(),
    updatetime datetime default now(),
    `state` int default 1
) default charset 'utf8mb4';
-- 创建文章表
drop table if exists  articleinfo;
create table articleinfo(
    id int primary key auto_increment,
    title varchar(100) not null,
    content text not null,
    createtime datetime default now(),
    updatetime datetime default now(),
    uid int not null,
    rcount int not null default 1,
    `state` int default 1
)default charset 'utf8mb4';
-- 创建视频表
drop table if exists videoinfo;
create table videoinfo(
    vid int primary key,
    `title` varchar(250),
    `url` varchar(1000),
  createtime datetime default now(),
  updatetime datetime default now(),
    uid int
)default charset 'utf8mb4';
-- 添加一个用户信息
INSERT INTO `mycnblog`.`userinfo` (`id`, `username`, `password`, `photo`, `createtime`, `updatetime`, `state`) VALUES 
(1, 'admin', 'admin', '', '2021-12-06 17:10:48', '2021-12-06 17:10:48', 1);
-- 文章添加测试数据
insert into articleinfo(title,content,uid)
    values('Java','Java正文',1);
-- 添加视频
insert into videoinfo(vid,title,url,uid) values(1,'java title','http://www.baidu.com',1);


将代码在MySQL客户端进行复制运行。


2.2 使用MyBatis的操作模式操作数据库


下图按照后端开发的工程思路,也就是下面的流程来实现MyBatis操作数据库。


微信图片_20230111210803.png

在我的文章【Spring更简单的存储和读取Bean】1.3中有下边这样一幅图,展示了程序各个工程的分层,所以我们实现业务代码就是需要按照这样的分层来实现。


微信图片_20230111210800.png

先在项目的启动类的同一级目录中创建包,做好项目的分层工作。


微信图片_20230111210757.png

2.2.1 添加实体类


在model包下先添加用户的实体类


微信图片_20230111210753.png

2.2.2 添加mapper接口


数据持久层的接口定义:


微信图片_20230111210749.png

2.2.3 添加UserMapper.xml


数据持久层的实现,MyBatis的固定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">
<!-- namespace 要设置是实现接口的具体包名加接口名 -->
<mapper namespace="com.example.demo.mapper.UserMapper">
</mapper>


微信图片_20230111210746.png


2.2.4 添加Service


在service包下实现服务层代码:


微信图片_20230111210742.png

2.2.5 添加Controller


在controller包下实现控制器层:


微信图片_20230111210738.png

2.2.6 测试


在浏览器中输入URL进行测试:

微信图片_20230111210733.png



3.总结:MyBatis执行流程图

微信图片_20230111210725.png


相关文章
|
7月前
|
SQL XML Java
MyBatis Mapper中使用limit参数的查询问题
总结而言,MyBatis中使用 `limit`参数的查询可以高度定制并且灵活,基于方法签名和XML映射文件的组合来达成多样化的查询需求。通过参数化查询和动态SQL,MyBatis可以有效地处理各种复杂情境下的数据库操作,并且将SQL语句的维护与业务代码的编写相分离,提升代码的可维护性和可阅读性。
644 13
|
8月前
|
SQL Java 数据库
解决Java Spring Boot应用中MyBatis-Plus查询问题的策略。
保持技能更新是侦探的重要素质。定期回顾最佳实践和新技术。比如,定期查看MyBatis-Plus的更新和社区的最佳做法,这样才能不断提升查询效率和性能。
406 1
|
Java 数据库连接 数据库
mybatis查询数据,返回的对象少了一个字段
mybatis查询数据,返回的对象少了一个字段
1211 9
|
XML Java 数据库连接
Mybatis一对一,一对多关联查询
## MyBatis一对一、一对多关联查询详解 MyBatis是一款优秀的持久层框架,提供了灵活的SQL映射功能,支持复杂的数据库操作。本文将详细介绍MyBatis中一对一和一对多关联查询的实现。 ### 一对一关联查询 一对一关联关系指的是一个表中的一条记录与另一个表中的一条记录相关联。例如,一个用户有一个地址信息。 #### 数据库表设计 假设有两个表:`user`和 `address`。 ``` CREATE TABLE user ( id INT PRIMARY KEY, name VARCHAR(50) ); CREATE TABLE address
426 18
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
1580 6
|
SQL Java 关系型数据库
Mybatis多表关联查询与动态SQL(下)
Mybatis多表关联查询与动态SQL
380 0
|
SQL Java 数据库连接
Mybatis多表关联查询与动态SQL(上)
Mybatis多表关联查询与动态SQL
485 0
|
SQL 缓存 Java
mybatis 一对多查询
mybatis 一对多查询
440 0
|
XML Java 数据库连接
Mybatis实现RBAC权限模型查询
通过对RBAC权限模型的理解和MyBatis的灵活使用,我们可以高效地实现复杂的权限管理功能,为应用程序的安全性和可维护性提供有力支持。
414 5
|
SQL 安全 Java
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
MyBatis-Plus 提供了一套强大的条件构造器(Wrapper),用于构建复杂的数据库查询条件。Wrapper 类允许开发者以链式调用的方式构造查询条件,无需编写繁琐的 SQL 语句,从而提高开发效率并减少 SQL 注入的风险。
436 2
MyBatis-Plus条件构造器:构建安全、高效的数据库查询