private String address;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return “User{” +
“id=” + id +
“, username='” + username + ‘’’ +
“, birthday=” + birthday +
“, sex='” + sex + ‘’’ +
“, address='” + address + ‘’’ +
‘}’;
}
}
IUserDao:
package com.keafmd.dao;
import com.keafmd.domain.User;
import org.apache.ibatis.annotations.Select;
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();
}
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;
测试代码:
package com.keafmd.test;
import com.keafmd.dao.IUserDao;
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.IOException;
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 SqlSession sqlsession;
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.使用工厂生产SqlSession对象
sqlsession = factory.openSession();
//4.使用SqlSession创建Dao接口的代理对象
userDao = sqlsession.getMapper(IUserDao.class);
}
@After // 用于在测试方法执行后执行
public void destory() throws Exception{
//提交事务
sqlsession.commit();
//6.释放资源
sqlsession.close();
in.close();
}
/**
-
查询所有
-
@throws Exception
*/
@Test
public void testFindAll() throws Exception {
//5.使用代理对象执行方法
List users = userDao.findAll();
for (User user : users) {
System.out.println(user);
}
}
/**
- 测试保存操作
*/
@Test
public void testSave() throws Exception {
User user = new User();
user.setUsername(“Keafmd laset insertid”);
user.setSex(“男”);
user.setBirthday(new Date());
user.setAddress(“XXXXXXX”);
System.out.println(“保存操作前:”+user);
//5.执行保存方法
userDao.saveUser(user);
System.out.println(“保存操作后:”+user);
}
/**
-
测试更新
-
@throws Exception
*/
@Test
public void testUpdate() throws Exception {
User user = new User();
user.setId(42);
user.setUsername(“update”);
user.setSex(“男”);
user.setBirthday(new Date());
user.setAddress(“XXXXXXX”);
//5.执行更新方法
userDao.updateUser(user);
}
/**
-
测试删除
-
@throws Exception
*/
@Test
这里分享一份由字节前端面试官整理的「2021大厂前端面试手册」,内容囊括Html、CSS、Javascript、Vue、HTTP、浏览器面试题、数据结构与算法。全部整理在下方文档中,共计111道
HTML
-
HTML5有哪些新特性?
-
Doctype作⽤? 严格模式与混杂模式如何区分?它们有何意义?
-
如何实现浏览器内多个标签页之间的通信?
-
⾏内元素有哪些?块级元素有哪些? 空(void)元素有那些?⾏内元 素和块级元素有什么区别?
-
简述⼀下src与href的区别?
-
cookies,sessionStorage,localStorage 的区别?
-
HTML5 的离线储存的使用和原理?
-
怎样处理 移动端 1px 被 渲染成 2px 问题?
-
iframe 的优缺点?
-
Canvas 和 SVG 图形的区别是什么?
JavaScript
-
问:0.1 + 0.2 === 0.3 嘛?为什么?
-
JS 数据类型
-
写代码:实现函数能够深度克隆基本类型
-
事件流
-
事件是如何实现的?
-
new 一个函数发生了什么
-
什么是作用域?
-
JS 隐式转换,显示转换
-
了解 this 嘛,bind,call,apply 具体指什么
-
手写 bind、apply、call
-
setTimeout(fn, 0)多久才执行,Event Loop
-
手写题:Promise 原理
-
说一下原型链和原型链的继承吧
-
数组能够调用的函数有那些?
-
PWA使用过吗?serviceWorker的使用原理是啥?
-
ES6 之前使用 prototype 实现继承
-
箭头函数和普通函数有啥区别?箭头函数能当构造函数吗?
-
事件循环机制 (Event Loop)