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

*/

public class User {

//属性名和数据库表的字段对应

private int id;

private String username;// 用户姓名

private String sex;// 性别

private Date birthday;// 生日

private String address;// 地址

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public Date getBirthday() {

return birthday;

}

public void setBirthday(Date birthday) {

this.birthday = birthday;

}

public String getAddress() {

return address;

}

public void setAddress(String address) {

this.address = address;

}

@Override

public String toString() {

return “User [id=” + id + “, username=” + username + “, sex=” + sex

  • “, 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.易于上手和掌握。

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

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

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

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

学习分享,共勉

这里是小编拿到的学习资源,其中包括“中高级Java开发面试高频考点题笔记300道.pdf”和“Java核心知识体系笔记.pdf”文件分享,内容丰富,囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。同时还有Java进阶学习的知识笔记脑图(内含大量学习笔记)!

资料整理不易,读者朋友可以转发分享下!

Java核心知识体系笔记.pdf

记一次蚂蚁金服Java研发岗的面试经历,分享下我的复习笔记面经

中高级Java开发面试高频考点题笔记300道.pdf

记一次蚂蚁金服Java研发岗的面试经历,分享下我的复习笔记面经

架构进阶面试专题及架构学习笔记脑图

记一次蚂蚁金服Java研发岗的面试经历,分享下我的复习笔记面经

Java架构进阶学习视频分享
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
包括“中高级Java开发面试高频考点题笔记300道.pdf”和“Java核心知识体系笔记.pdf”文件分享,内容丰富,囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。同时还有Java进阶学习的知识笔记脑图(内含大量学习笔记)!

资料整理不易,读者朋友可以转发分享下!

Java核心知识体系笔记.pdf

[外链图片转存中…(img-JPe62Ql7-1713477374901)]

中高级Java开发面试高频考点题笔记300道.pdf

[外链图片转存中…(img-xalVMyxD-1713477374903)]

架构进阶面试专题及架构学习笔记脑图

[外链图片转存中…(img-k37sgu00-1713477374905)]

Java架构进阶学习视频分享
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 28
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值