后端开发基础-MyBatis框架学习-001——基础概念

文章详细介绍了MyBatis中的Mapper映射器接口如何用于实现数据库操作,如查询、插入、更新和删除,以CostDAO为例,展示了如何针对资费表进行各种操作。内容包括接口规则、示例代码和工程目录结构。
摘要由CSDN通过智能技术生成

Mapper映射器(接口)


MyBatis提供了一个Mapper映射器接口规则,

按规则写出的接口,MyBatis框架可以自动生成

实现组件对象。

UserDAO接口—》JdbcUserDAO实现类

—》生成对象使用

Mapper映射器接口—》生成对象使用

映射器接口接口规则:

-方法名参考SQL定义的id属性(保持一致)

-方法参数类型参考SQL定义的

parameterType属性(保持一致)

-方法返回类型

增删改:可以是void 或 int

查询:单行结果类型为resultType

多行结果类型为List

-将SQL定义文件元素的

namespace属性指定为”包名.接口名”

映射器接口的使用:

sqlSession.getMapper(接口.class);

UserDAO dao = new $Proxy4();

public class $Proxy4 implements UserDAO{

public List findAll(){

return session.selectList(“findAll”);

}

public User findById(int id){

return session.selectOne(

“findById”,id);

}

}

=任务=

利用MyBatis对资费表进行以下操作

-查询所有资费记录

-按ID查询资费记录

-添加资费记录

-删除资费记录

-更新资费记录

-编写CostDAO映射器接口实现上述操作

案例演示:

案例思路:

工程案例目录结构

pom.xml

4.0.0

com.study

mybatis-day07

0.0.1-SNAPSHOT

war

org.mybatis

mybatis

3.3.0

com.oracle

ojdbc14

10.2.0.4.0

junit

junit

4.12

SqlMapConfig.xml

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

UserMapper.xml

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

SELECT ID,NAME FROM user_dk

WHERE ID=#{id}

<select id=“findLikeName” parameterType=“string”

resultType=“com.dk.entity.User”>

SELECT * FROM user_dk

WHERE NAME like #{name}

DELETE FROM user_dk

WHERE ID = #{id}

UPDATE user_dk

SET NAME=#{name},AGE=#{age}

WHERE ID=#{id}

INSERT INTO user_dk (ID,NAME,AGE)

VALUES (#{id},#{name},#{age})

SELECT * FROM user_dk

SELECT * FROM user_dk

WHERE id = #{id}

User.java

package com.dk.entity;

import java.io.Serializable;

public class User implements Serializable{

private Integer id;

private String name;

private Integer age;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public Integer getAge() {

return age;

}

public void setAge(Integer age) {

this.age = age;

}

}

MyBatisUtil.java

package com.dk.entity;

import java.io.IOException;

import java.io.Reader;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

public class MyBatisUtil {

public static SqlSession getSession() throws IOException{

SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();

String conf = “SqlMapConfig.xml”;

Reader reader = Resources.getResourceAsReader(conf);

SqlSessionFactory factory = builder.build(reader);

SqlSession session = factory.openSession();

return session;

}

public static void main(String[] args) throws IOException {

SqlSession session = MyBatisUtil.getSession();

System.out.println(session);

}

}

TestUser.java

package com.test;

import java.io.IOException;

import java.util.List;

import java.util.Map;

import org.apache.ibatis.session.SqlSession;

import org.junit.Test;

import com.dk.dao.UserDAO;

import com.dk.entity.MyBatisUtil;

import com.dk.entity.User;

public class TestUser {

@Test//测试Mapper映射器接口

public void test8() throws IOException{

SqlSession session = MyBatisUtil.getSession();

//根据接口生成实现对象

UserDAO dao = session.getMapper(UserDAO.class);

System.out.println(dao.getClass().getName());

//调用 id = findAll的SQL语句

List list = dao.findAll();

for(User user:list){

System.out.println(user.getId()+" "+user.getName());

}

session.close();

}

@Test//测试查询返回Map

public void test7() throws IOException{

SqlSession session = MyBatisUtil.getSession();

Map<String,Object> map = session.selectOne(“findName”, 1);

if(map != null){//利用字段名做key提取值

System.out.println(map.get(“ID”)+" "+map.get(“NAME”));

}else{

System.out.println(“未找到数据”);

}

session.close();

}

@Test//测试模糊查询

public void test6() throws IOException{

SqlSession session = MyBatisUtil.getSession();

List list = session.selectList(“findLikeName”, “%D%”);

for(User user:list){

System.out.println(user.getName());

}

session.close();

}

@Test//测试删除

public void test5() throws IOException{

SqlSession session = MyBatisUtil.getSession();

//执行删除

int rows = session.delete(“deleteUser”, 10);

System.out.println(“删除的记录行数:”+rows);

session.commit();

session.close();

}

@Test//测试更新

public void test4() throws IOException{

SqlSession session = MyBatisUtil.getSession();

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

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

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

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

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

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

img

最后

整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

image

image

其实面试这一块早在第一个说的25大面试专题就全都有的。以上提及的这些全部的面试+学习的各种笔记资料,我这差不多来回搞了三个多月,收集整理真的很不容易,其中还有很多自己的一些知识总结。正是因为很麻烦,所以对以上这些学习复习资料感兴趣
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
点,真正体系化!**

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

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

img

最后

整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

[外链图片转存中…(img-MTyfR8wt-1713583855516)]

[外链图片转存中…(img-Fk3a7jul-1713583855516)]

其实面试这一块早在第一个说的25大面试专题就全都有的。以上提及的这些全部的面试+学习的各种笔记资料,我这差不多来回搞了三个多月,收集整理真的很不容易,其中还有很多自己的一些知识总结。正是因为很麻烦,所以对以上这些学习复习资料感兴趣
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 14
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值