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开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

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

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值