==============================================================
====================================================================
IUserDao:
package com.keafmd.dao;
import com.keafmd.domain.User;
import java.util.List;
/**
-
Keafmd
-
@ClassName: IUserDao
-
@Description: 用户的持久层接口
-
@author: 牛哄哄的柯南
-
@date: 2021-02-06 19:29
*/
public interface IUserDao {
/**
-
查询所有操作
-
@return
*/
List findAll();
/**
-
保存用户
-
@param user
*/
void saveUser(User user);
/**
-
更新用户
-
@param user
*/
void updateUser(User user);
/**
-
根据id删除用户
-
@param id
*/
void deleteUser(Integer id);
/**
-
根据id查新用户信息
-
@param id
-
@return
*/
User findById(Integer id);
/**
-
根据名称模糊查询
-
@param username
-
@return
*/
List findByName(String username);
/**
-
查询总用户数
-
@return
*/
int findTotal();
}
=====================================================================
UserDaoImpl:
package com.keafmd.dao.impl;
import com.keafmd.dao.IUserDao;
import com.keafmd.domain.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import java.util.List;
/**
-
Keafmd
-
@ClassName: UserDaoImpl
-
@Description:
-
@author: 牛哄哄的柯南
-
@date: 2021-02-09 11:09
*/
public class UserDaoImpl implements IUserDao {
private SqlSessionFactory factory;
public UserDaoImpl(SqlSessionFactory factory){
this.factory=factory;
}
public List findAll() {
//1.根据factory获取SQLSession对象
SqlSession session = factory.openSession();
//2.调用SqlSession中的方法,实现查询列表
List users = session.selectList(“com.keafmd.dao.IUserDao.findAll”);//参数为能获取配置信息的key
//3.释放资源
session.close();
return users;
}
public void saveUser(User user) {
//1.根据factory获取SQLSession对象
SqlSession session = factory.openSession();
//2.调用SqlSession中的方法,实现保存
session.insert(“com.keafmd.dao.IUserDao.saveUser”,user);
//3.提交事务
session.commit();
//释放资源
session.close();
}
public void updateUser(User user) {
//1.根据factory获取SQLSession对象
SqlSession session = factory.openSession();
//2.调用SqlSession中的方法,实现更新
session.update(“com.keafmd.dao.IUserDao.updateUser”,user);
//3.提交事务
session.commit();
//释放资源
session.close();
}
public void deleteUser(Integer id) {
//1.根据factory获取SQLSession对象
SqlSession session = factory.openSession();
//2.调用SqlSession中的方法,实现更新
session.update(“com.keafmd.dao.IUserDao.deleteUser”,id);
//3.提交事务
session.commit();
//释放资源
session.close();
}
public User findById(Integer id) {
//1.根据factory获取SQLSession对象
SqlSession session = factory.openSession();
//2.调用SqlSession中的方法,实现查询一个
User user = session.selectOne(“com.keafmd.dao.IUserDao.findById”,id);//参数为能获取配置信息的key
//3.释放资源
session.close();
return user;
}
public List findByName(String username) {
//1.根据factory获取SQLSession对象
SqlSession session = factory.openSession();
//2.调用SqlSession中的方法,实现查询列表
List users = session.selectList(“com.keafmd.dao.IUserDao.findByName”,username);//参数为能获取配置信息的key
//3.释放资源
session.close();
return users;
}
public int findTotal() {
//1.根据factory获取SQLSession对象
SqlSession session = factory.openSession();
return session.selectOne(“com.keafmd.dao.IUserDao.findTotal”);
}
}
=================================================================
IUserDao.xml:
<?xml version="1.0" encoding="UTF-8"?>select * from user
select last_insert_id();
insert into user(username,address,sex,birthday)values(#{username},#{address},#{sex},#{birthday});
update user set username=#{username},address=#{address},sex=#{sex},birthday=#{birthday} where id=#{id}
delete from user where id = #{uid}
select * from user where id = #{id}
select * from user where username like ‘%${value}%’
select count(id) from user;
=============================================================
MybatisTest:
package com.keafmd.test;
import com.keafmd.dao.IUserDao;
import com.keafmd.dao.impl.UserDaoImpl;
import com.keafmd.domain.User;
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.After;
import org.junit.Before;
import org.junit.Test;
import java.io.InputStream;
import java.util.Date;
import java.util.List;
/**
-
Keafmd
-
@ClassName: MybatisTest
-
@Description: 测试类,测试crud操作
-
@author: 牛哄哄的柯南
-
@date: 2021-02-08 15:24
*/
public class MybatisTest {
private InputStream in;
private IUserDao userDao;
@Before // 用于在测试方法执行前执行
public void init()throws Exception{
//1.读取配置文件,生成字节输入流
in = Resources.getResourceAsStream(“SqlMapConfig.xml”);
//2.创建SqlSessionFactory工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(in);
//3.使用工厂对象创建dao对象
感受:
其实我投简历的时候,都不太敢投递阿里。因为在阿里一面前已经过了字节的三次面试,投阿里的简历一直没被捞,所以以为简历就挂了。
特别感谢一面的面试官捞了我,给了我机会,同时也认可我的努力和态度。对比我的面经和其他大佬的面经,自己真的是运气好。别人8成实力,我可能8成运气。所以对我而言,我要继续加倍努力,弥补自己技术上的不足,以及与科班大佬们基础上的差距。希望自己能继续保持学习的热情,继续努力走下去。
也祝愿各位同学,都能找到自己心动的offer。
分享我在这次面试前所做的准备(刷题复习资料以及一些大佬们的学习笔记和学习路线),都已经整理成了电子文档
= Resources.getResourceAsStream(“SqlMapConfig.xml”);
//2.创建SqlSessionFactory工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(in);
//3.使用工厂对象创建dao对象
感受:
其实我投简历的时候,都不太敢投递阿里。因为在阿里一面前已经过了字节的三次面试,投阿里的简历一直没被捞,所以以为简历就挂了。
特别感谢一面的面试官捞了我,给了我机会,同时也认可我的努力和态度。对比我的面经和其他大佬的面经,自己真的是运气好。别人8成实力,我可能8成运气。所以对我而言,我要继续加倍努力,弥补自己技术上的不足,以及与科班大佬们基础上的差距。希望自己能继续保持学习的热情,继续努力走下去。
也祝愿各位同学,都能找到自己心动的offer。
分享我在这次面试前所做的准备(刷题复习资料以及一些大佬们的学习笔记和学习路线),都已经整理成了电子文档
[外链图片转存中…(img-Bvb7wV4G-1718772534648)]