1. 创建数据表
a) 确定表名(如:role)
b) 确定表中的业务列(如:role_name、role_desc)
c) 添加其它基本列
i. 如:role_id(主键)、status(数据状态,用来支持逻辑删除)、remark(给数据库管理员或程序员用的备注)、creater(用来记录数据的创建人)、create_time(用来记录数据的创建时间)、updater(用来记录数据的最后更新人)、update_time(用来记录数据的最后更新时间)
d) 检查列属性是否正确(如:自增、主键、不能Null、默认值、类型、长度)
e) 检查列名及表名是否正确(确保没有拼写错误)
2. 创建模块类(下面以Role模块为例)
a) 在com.zhiyou100.crm.model中创建Role类
b) 按照role数据表为Role类添加属性(注意驼峰命名法)
i. 注意日期时间用Timestamp类型
c) 添加toString()方法,以方便打印Role对象
d) 为属性生成getter/setter方法,一定要使用Eclipse生成,不要自己手敲
3. 创建RoleDao接口
a) int add(Role role); 用来添加数据
b) int update(Role role); 用来更新数据
c) int remove(int roleId); 用来删除数据
d) 上面3个方法返回的都是受影响的行数
e) Role get(int roleId); 根据id查出单条数据
f) List<Role> list(); 查出所有有效数据
g) 上面2个方法返回的是业务数据
4. 创建RoleDaoImpl类
a) 实现RoleDao接口
b) 实现RoleDao接口中定义的各个方法
c) 实现add、update、remove方法都是4步
i. 拼SQL
ii. 建连接和语句对象
iii. 设置SQL参数
iv. 调用executeUpdate()方法
d) 实现get、list方法是5步
i. 拼SQL
ii. 建连接和语句对象
iii. 设置SQL参数
iv. 调用executeQuery ()方法
v. 将数据从ResultSet中读取到Role对象中
5. 创建RoleService接口
a) 添加 int add(Role role); int update(Role role); int remove(int roleId); 方法
b) 添加 Role get(int roleId); List<Role> list(); 方法
6. 创建RoleServiceImpl类
a) 实现RoleService接口
b) 实现RoleService接口中定义的各个方法
c) 都是通过调用RoleDao(RoleDaoImpl)中的方法实现
7. 添加列表页面(先不实现数据展示功能)
a) 在/WEB-INF/view/中新建role文件夹,role模块的视图都放在这个文件夹中
b) 在/WEB-INF/view/role中新建list.jsp,将列表页的HTML复制进去
i. 修改文字
ii. 修改各处URL为<c:url value=”” />,注意添加taglib指令导入JSTL标签库,下面不再提示!
c) 在com.zhiyou100.crm.servlet.role中创建ListServlet,设置映射URL为/role/list
i. 在doGet()方法中,将请求转发到 /WEB-INF/view/role/list.jsp,以显示列表页面
d) 修改list.jsp页面中的“新增”按扭的URL为<c:url value=”/role/add” />,以便跳到新增页面
8. 新增功能开发
a) 在/WEB-INF/view/role中新建add.jsp,将前端给的HTML复制进去,修改文字
i. 注意检查<form>的action属性中的URL及method是否为POST
ii. 注意检查<input>等表单控件的name属性是否拼写正确
b) 在com.zhiyou100.crm.servlet.role中创建AddServlet
i. 设置映射URL为/role/add
ii. 在doGet()方法中将请求转发到/WEB-INF/view/role/add.jsp,以显示新增表单页面
iii. 测试点新增按扭时能否跳到新增页面
iv. 在doPost()方法中收集表单传过来数据
1. roleName、roleDesc
2. 实现化一个Role类,将上面的数据set进去
3. 然后给role对象设置添加人、添加时间
4. 调用roleService.add()方法
a) 添加成功(返回值大于0)则重定向到/应用路径/role/list
b) 不成功则在请求中添加role对象和errorMessage,转发到/WEB-INF/view/role/add.jsp,以显示用户填写的数据和错误提示
c) 测试新增功能是否正常(新增成功后返回列表页,在数据库中可以看到新增加的数据)
9. 列表功能开发
a) 在ListServlet的doGet()方法中调用roleService.list()方法查询所有正常的数据
b) 将list数据放入请求对象中(请求已被转发给list.jsp)
c) 在list.jsp中,使用<c:forEach var=“r” items=”${requestScope.list}”> 渲染数据行</c:forEach>
d) 测试列表功能是否正常显示
i. 注意把鼠标入到编辑图标和删除图标上时,左下角的链接地址是否带有正确的id值
10. 删除功能开发
a) 添加RemoveServelt
b) 获取传过来的id值,转成整型roleId
c) 调用roleService.remove(roleId)方法删除数据
d) 重定向到列表页
11. 更新功能开发
a) 添加/WEB-INF/view/role/update.jsp
i. 注意在这个页面中,比add.jsp多了一个<input type=”hidden” name=”roleId” value=”${requestScope.role.roleId}” >,用来向UpdateServlet的doPost请求传递roleId数据
b) 添加UpdateServlet,实现编辑表单数据的显示
i. 在doGet()方法中获取id值,转成整型roleId
ii. 调用roleService.get(roleId)获取role对象
iii. 设置role对象到request对象中
iv. 转发到/WEB-INF/view/role/update.jsp
v. 测试更新页面能否正常打开
c) 实现数据更新
i. 在doPost()方法中获取传过来的roleId和roleName等业务数据
ii. 实例化并设置数据到role对象中
iii. 设置role对象的更新人、更新时间
iv. 调用roleService.update(role)方法更新数据
v. 更新成功则重定向到列表
vi. 失败则将role对象和errorMessage设置到request中,转发到update.jsp