-
项目结构
-
持久层 Dao 接口
-
持久层 Dao 实现类
-
持久层映射配置
-
测试类
==============================================================

====================================================================
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;
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。**
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-S4Lp4uRZ-1715574317033)]
[外链图片转存中…(img-HKQP38rN-1715574317034)]
[外链图片转存中…(img-gW5JhUK5-1715574317035)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
1045

被折叠的 条评论
为什么被折叠?



