====================================================================
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
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

总结一下这三次面试下来我的经验是:
-
一定不要死记硬背,要理解原理,否则面试官一深入就会露馅!
-
代码能力一定要注重,尤其是很多原理性的代码(之前两次让我写过Node中间件,Promise.all,双向绑定原理,被虐的怀疑人生)!
-
尽量从面试官的问题中表现自己知识的深度与广度,让面试官发现你的闪光点!
-
多刷面经!
我把所有遇到的面试题都做了一个整理,并且阅读了很多大牛的博客之后写了解析,免费分享给大家,算是一个感恩回馈吧,有需要的朋友【点击我】免费获取。祝大家早日拿到自己心怡的工作!
篇幅有限,仅展示部分内容
硬背,要理解原理,否则面试官一深入就会露馅!
-
代码能力一定要注重,尤其是很多原理性的代码(之前两次让我写过Node中间件,Promise.all,双向绑定原理,被虐的怀疑人生)!
-
尽量从面试官的问题中表现自己知识的深度与广度,让面试官发现你的闪光点!
-
多刷面经!
我把所有遇到的面试题都做了一个整理,并且阅读了很多大牛的博客之后写了解析,免费分享给大家,算是一个感恩回馈吧,有需要的朋友【点击我】免费获取。祝大家早日拿到自己心怡的工作!
篇幅有限,仅展示部分内容