作者:叩丁狼教育,钟昕灵老师。原创文章,转载请注明出处
开篇介绍:
经常有学员问我说,老师我之前学习过的很多知识点都忘了,怎么去弥补啊?我的建议往往都是花2~3个小时的连续时间,把之前已学习的多个零散知识点通过做一个综合案例串烧起来.
特此,在上把这个案例以文字的形式分享出来,希望能帮助到正在学习JavaWeb的童鞋.
所以,这篇JavaWeb综合案例系列文章,讲解了学习完JavaWeb阶段所有的知识点的综合应用,目的是希望在大家学完零碎的知识点后能够清楚地掌握各个技术在项目中的实际应用以及一个简单的Web项目的开发流程.既能复习到整个Web中重要的知识点,又能巩固已学过的知识.
开发工具: IDEA
开发环境: Tomcat7+JDK1.8+MySQL5.6
使用技术: JSP+Servlet+MyBatis+BootStrap+EL+JSTL
PS:MyBatis仅仅是一个入门级的使用,如果学习了后面MyBatis的高级部分,持久层能够使用更简单的方式实现
项目需求:
部门管理模块:
新增/删除/编辑/查询/分页查询
员工管理模块:
新增/删除/编辑/查询/高级查询/分页查询
登录模块
用户登录/用户注销/验证码/记住账号/登录检查/创建默认账户
功能展示:
1.登录页面
2.部门列表
3.部门编辑
4.员工列表
5.员工编辑
项目环境搭建
1.在javaweb数据库中创建了下面两张表
部门表
CREATE TABLE `department` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL,
`sn` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
员工表
CREATE TABLE `employee` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL,
`password` varchar(255) DEFAULT NULL,
`email` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`admin` bit(1) DEFAULT NULL,
`dept_id` bigint(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=20 DEFAULT CHARSET=utf8;
数据可以自行添加,能够用来对功能进行测试即可
2.创建JavaWeb项目,添加相关jar包
如果大家使用的Maven项目,则可以直接在项目的pom.xml文件中添加下面依赖即可:
jstl
jstl
1.2
javax.servlet
javax.servlet-api
3.1.0
provided
org.projectlombok
lombok
1.16.20
junit
junit
4.12
com.alibaba
druid
1.1.9
mysql
mysql-connector-java
5.1.38
org.mybatis
mybatis
3.4.5
log4j
log4j
1.2.17
org.slf4j
slf4j-api
1.7.25
org.slf4j
slf4j-log4j12
1.7.25
因为我们持久层使用的是MyBatis,所以需要先把框架的基本环境搭建好
MyBatis的环境中最主要的就是两大配置文件
1.mybatis主配置文件:mybatis-config.xml
每个配置的作用请参考配置中的注释信息
该配置文件主要在提供持久层操作数据库的过程中需要的基本信息,如:连接池/事务管理器/SQL所在的mapper文件等,有了这些信息后,我们就能够使用MyBatis执行指定的SQL操作数据了
2.Mapper映射文件
我们需要在mapper配置文件中编写需要执行的SQL,这里,我们先把执行基本增删改查的SQL准备好
DELETE FROM department
WHERE id = #{id}
INSERT INTO department (name, sn)
VALUES (#{name}, #{sn})
UPDATE department
SET name = #{name},
sn = #{sn}
WHERE id = #{id}
Mapper配置中的相关解释:
1.mapper的namespace和sqlid用来确定唯一的一条SQL
2.keyColumn keyProperty useGeneratedKeys:当需要获取当前保存数据在数据库中自动生成的主键的时候使用
3.SQL中的#{}会在加载当前配置文件后,翻译成占位符?,然后使用其中指定的属性名获取到传递过来的对象中的属性值
#{name}---->获取Department对象中的name属性值
4.resultType用来执行将查询结果中的每行数据封装成什么类型的对象
好了,mybatis的两个配置文件以及配置的内容到此搞定,接下来就会开始使用mybatis提供的相关api来完成CRUD吧
创建实体类:封装部门相关的属性,在封装对象的时候都使用包装类型
@Setter
@Getter
public class Department {
private Long id;
private String name;
private String sn;
}
创建DAO接口和实现类:执行mapper中编写的SQL,完成持久层的CRUD操作
按规范,接口中的每个方法都应该加上详细的注释
在这个阶段,由于还没有学习过mybatis中的Mapper接口实现,所以,我们暂且使用基本的API来实现
public interface IDepartmentDAO {
/**
* 保存部门信息
* @param record 部门数据封装的对象
*/
void insert(Department record);
/**
* 删除部门信息
* @param id 需要删除数据的主键id
*/
void deleteByPrimaryKey(Long id);
/**
* 根据主键id更新部门信息
* @param record 部门数据封装的对象
*/
void updateByPrimaryKey(Department record);
/**
* 根据主键id查询部门信息
* @param id 需要查询的部门id
* @return 返回查询到的部门对象,如果没有,返回null
*/
Department selectByPrimaryKey(Long id);
/**
* 查询部门表中的所有数据
* @return 返回查询到的所有部门信息,如果没有,返回size=0的集合
*/
List selectAll();
}
public class DepartmentDAOImpl implements IDepartmentDAO {
public void insert(Department record) {
SqlSession session = MyBatisUtil.openSession();
session.delete("cn.wolfcode.javaweb.mapper.DepartmentMapper.insert", record);
session.commit();
session.close();
}
public void deleteByPrimaryKey(Long id) {
SqlSession session = MyBatisUtil.openSession();
session.delete("cn.wolfcode.javaweb.mapper.DepartmentMapper.deleteByPrimaryKey", id);
session.commit();
session.close();
}
public void updateByPrimaryKey(Department record) {
SqlSession session = MyBatisUtil.openSession();
session.delete("cn.wolfcode.javaweb.mapper.DepartmentMapper.updateByPrimaryKey", record);
session.commit();
session.close();
}
public Department selectByPrimaryKey(Long id) {
SqlSession session = MyBatisUtil.openSession();
Department department = session.selectOne("cn.wolfcode.javaweb.mapper.DepartmentMapper.selectByPrimaryKey", id);
session.close();
return department;
}
public List selectAll() {
SqlSession session = MyBatisUtil.openSession();
List list = session.selectList("cn.wolfcode.javaweb.mapper.DepartmentMapper.selectAll");
session.close();
return list;
}
}
编写测试类,对DAO中每个方法进行测试,直到每个方法都能够按照需求正确的执行即可
service层接口和实现类的实现:由于在目前需求中,没有多余的业务,只是完成基本的CRUD,所以,在service中直接调用到中的方法完成即可
public interface IDepartmentService {
/**
* 保存部门信息
*
* @param entity 部门数据封装的对象
*/
void save(Department entity);
/**
* 根据主键id更新部门信息
*
* @param entity 部门数据封装的对象
*/
void update(Department entity);
/**
* 删除部门信息
*
* @param id 需要删除数据的主键id
*/
void delete(Long id);
/**
* 根据主键id查询部门信息
*
* @param id 需要查询的部门id
* @return 返回查询到的部门对象, 如果没有, 返回null
*/
Department get(Long id);
/**
* 查询部门表中的所有数据
*
* @return 返回查询到的所有部门信息, 如果没有, 返回size=0的集合
*/
List list();
}
public class DepartmentServiceImpl implements IDepartmentService {
// 关联DAO对象
private IDepartmentDAO dao = new DepartmentDAOImpl();
public void save(Department entity) {
dao.insert(entity);
}
public void update(Department entity) {
dao.updateByPrimaryKey(entity);
}
public void delete(Long id) {
dao.deleteByPrimaryKey(id);
}
public Department get(Long id) {
return dao.selectByPrimaryKey(id);
}
public List list() {
return dao.selectAll();
}
点击查看JavaWeb系列的其它文章
手把手教你做JavaWeb项目:前台界面
手把手教你做JavaWeb项目:多条件过滤
手把手教你做JavaWeb项目:登录模块
前往叩丁狼官网获取更多技术视频