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开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/7b64f14d3ce1b1d8fd0a6ede23c2327c.jpeg)
最后
整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
其实面试这一块早在第一个说的25大面试专题就全都有的。以上提及的这些全部的面试+学习的各种笔记资料,我这差不多来回搞了三个多月,收集整理真的很不容易,其中还有很多自己的一些知识总结。正是因为很麻烦,所以对以上这些学习复习资料感兴趣
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
点,真正体系化!**
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/7b64f14d3ce1b1d8fd0a6ede23c2327c.jpeg)
最后
整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
[外链图片转存中…(img-MTyfR8wt-1713583855516)]
[外链图片转存中…(img-Fk3a7jul-1713583855516)]
其实面试这一块早在第一个说的25大面试专题就全都有的。以上提及的这些全部的面试+学习的各种笔记资料,我这差不多来回搞了三个多月,收集整理真的很不容易,其中还有很多自己的一些知识总结。正是因为很麻烦,所以对以上这些学习复习资料感兴趣
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!