MyBatis入门学习教程,最详细的原理使用讲解(1)

  • “, birthday=” + birthday + “, address=” + address + “]”;

}

}

第四步、实现增删改查的功能,首先编写User.xml中的内容,如下所示:

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

SELECT * FROM USER WHERE id=#{value}

SELECT * FROM USER WHERE username LIKE ‘%${value}%’

SELECT LAST_INSER_ID()

insert into user(username,birthday,sex,address) value(#{username},#{birthday},#{sex},#{address})

SELECT uuid()

insert into user(username,birthday,sex,address) value(#{username},#{birthday},#{sex},#{address});

delete from user where id=#{id}

update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address}

where id=#{id}

第五步、编写具体的方法,如下所示:

package cn.itcast.mybatis.first;

import java.io.IOException;

import java.io.InputStream;

import java.util.Date;

import java.util.List;

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 org.junit.Test;

import cn.itcast.mybatis.po.User;

public class MybatisFirst {

// 根据id查询用户信息,得到一条记录结果

@Test

public void findUserByIdTest() throws IOException {

// mybatis配置文件

String resource = “SqlMapConfig.xml”;

// 得到配置文件流

InputStream inputStream = Resources.getResourceAsStream(resource);

// 创建会话工厂,传入mybatis的配置文件信息

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()

.build(inputStream);

// 通过工厂得到SqlSession

SqlSession sqlSession = sqlSessionFactory.openSession();

// 通过SqlSession操作数据库

// 第一个参数:映射文件中statement的id,等于=namespace+“.”+statement的id

// 第二个参数:指定和映射文件中所匹配的parameterType类型的参数

// sqlSession.selectOne结果 是与映射文件中所匹配的resultType类型的对象

// selectOne查询出一条记录

User user = sqlSession.selectOne(“test.findUserById”, 1);

System.out.println(user);

// 释放资源

sqlSession.close();

}

//根据用户名称模糊查询用户列表

@Test

public void findUserByNameTest() throws IOException{

//mybatis配置文件

String resource =“SqlMapConfig.xml”;

//得到配置文件

InputStream inputStream = Resources.getResourceAsStream(resource);

//创建会话工厂,传入mybatis的配置文件信息

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

//通过工厂得到SqlSession

SqlSession sqlSession = sqlSessionFactory.openSession();

//List中的user和映射文件中德resultType所指定的类型一致

List list = sqlSession.selectList(“test.findUserByName”,“小明”);

System.out.println(list);

sqlSession.close();

}

public void insertUserTest() throws IOException{

//mybatis配置文件

String resource =“SqlMapConfig”;

//得到配置文件流

InputStream inputStream = Resources.getResourceAsStream(resource);

//创建会话工厂,传入mybatis的配置文件信息

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

//通过工厂得到sqlsession

SqlSession sqlSession = sqlSessionFactory.openSession();

//插入用户对象

User user = new User();

user.setUsername(“丁国华”);

user.setBirthday(new Date());

user.setSex(“1”);

user.setAddress(“安徽合肥”);

//list中的user和映射文件中的resultType所指定的类型一直

sqlSession.insert(“test.insertUser”,user);

//提交事物

sqlSession.commit();

//关闭会话

sqlSession.close();

}

//根据id删除用户信息

@Test

public void deleteUserTest() throws IOException{

//mybatis配置文件

String resource = “SqlMapConfig.xml”;

//得到配置文件流

InputStream inputStream = Resources.getResourceAsStream(resource);

//创建工厂,传入mybatis的配置文件信息

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

//通过工厂得到SqlSession

SqlSession sqlSession = sqlSessionFactory.openSession();

//传入id删除用户

sqlSession.delete(“test.deleteUser”,39);

//提交事物

sqlSession.commit();

//关闭会话

sqlSession.close();

}

// 更新用户信息

@Test

public void updateUserTest() throws IOException {

// mybatis配置文件

String resource = “SqlMapConfig.xml”;

// 得到配置文件流

InputStream inputStream = Resources.getResourceAsStream(resource);

// 创建会话工厂,传入mybatis的配置文件信息

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()

.build(inputStream);

// 通过工厂得到SqlSession

SqlSession sqlSession = sqlSessionFactory.openSession();

// 更新用户信息

User user = new User();

//必须设置id

user.setId(41);

user.setUsername(“丁国华”);

user.setBirthday(new Date());

user.setSex(“2”);

user.setAddress(“安徽合肥”);

sqlSession.update(“test.updateUser”, user);

// 提交事务

sqlSession.commit();

// 关闭会话

sqlSession.close();

}

}

mybatis的优缺点

===========

优点:

===

1.易于上手和掌握。

2.sql写在xml里,便于统一管理和优化。

3.解除sql与程序代码的耦合。

4.提供映射标签,支持对象与数据库的orm字段关系映射

5.提供对象关系映射标签,支持对象关系组建维护

6.提供xml标签,支持编写动态sql。

缺点:

===

1.sql工作量很大,尤其是字段多、关联表多时,更是如此。

2.sql依赖于数据库,导致数据库移植性差。

3.由于xml里标签id必须唯一,导致DAO中方法不支持方法重载。

4.DAO层过于简单,对象组装的工作量较大。

5.缓存使用不当,容易产生脏数据。

mybatis和hibernate的对比

====================

相同点:

====

Hibernate和mybatis都可以是通过SessionFactoryBuilder由xml配置文件生成SessionFactory,然后由SessionFactroy生成Session,最后由Session来开启执行事物和SQL语句,其中SessionFactoryBuider、SessionFactory、Session的生命周期都是差不多的。

不同点:

====

mybatis:小巧、方便、高效、简单、直接、半自动;

hibernate:强大、方便、高效、复杂、绕弯子、全自动;

mybatis:

========

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
,自己不成体系的自学效果低效漫长且无助。**

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-H69p1oLa-1714886694027)]

[外链图片转存中…(img-mWUAMw24-1714886694027)]

[外链图片转存中…(img-lGgeYaYK-1714886694028)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 25
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Boot、Vue-Element-Admin和MyBatis是一种常见的技术组合,用于构建现代化的Web应用程序。下面是一个简要的入门教程。 1. 首先,我们需要设置Spring Boot项目。可以使用Spring Initializr(https://start.spring.io/)来初始化一个基本的Spring Boot项目。在依赖项中添加Spring Web、Spring Data JPA和MyBatis等必要的依赖项。 2. 在Spring Boot项目中,我们需要创建实体类和数据库表的映射。使用JPA注解来定义实体类,并使用MyBatis注解来指定数据库表的映射。 3. 接下来,我们需要创建一个数据访问层(DAO)来处理与数据库的交互。使用MyBatis的注解或XML映射文件来定义SQL查询和操作。 4. 在Service层,编写业务逻辑代码来处理DAO返回的数据,并与其他组件进行交互。 5. 在Controller层,处理HTTP请求和响应,将数据传递给前端页面或接收前端发送的数据。使用Spring MVC注解来定义请求映射和参数解析。 6. 在前端方面,可以使用Vue-Element-Admin来构建用户界面。Vue是一种流行的JavaScript框架,用于构建灵活的单页面应用程序。Element-Admin是一个基于Vue的组件库,提供了丰富的UI组件和布局。 7. 在Vue-Element-Admin中,我们可以使用Vue Router来实现页面之间的导航和路由。使用axios来发送HTTP请求与后端进行数据交互。 8. 在Vue组件中,我们可以通过调用后端的API来获取数据并渲染到前端页面上。使用Element-Admin提供的布局和UI组件来美化页面。 通过上述步骤,我们可以实现一个基本的Spring Boot、Vue-Element-Admin和MyBatis入门教程。这个教程可以帮助初学者了解如何搭建和使用这个技术组合来构建现代化的Web应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值