代码分层之模拟servlet调用dao
一:代码分层
com.guangming.dao 存放dao相关的类型 例如 StudentDAOImpl 处理 数据库的链接 存取数据
com.guangming.servlet 存放servlet相关的类 例如:StudentServlet 处理 与浏览器交互的类
com.guangming.entity 存放实体类 例如 Student 接受数据库对象模型
com.guangming.util 存放工具类 例如 DBUtil
如图:
二:模拟servlet调用dao
步骤:
1 .创建一个数据库表 Student( id name age )
2 创建数据库表对应的实体类 (为什么要创建实体类?作用:以后数据库表中的数据 提取到 java中的时候 用 对象来存储)
3 创建DAO
A 组成 两部分: 接口 ( 声明 )和 实现类
接口的命名规则例如: IStudentDAO I 代表这是一个接口 Student 对应业务名称(表名) DAO 后缀 表明当前是一个dao接口
实现类的命名规则例如: StudentDAOImpl Student 代表业务名称(表名) DAOImpl 代表dao接口的实现
为什么需要接口+实现类? 因为 我们需要一个多态的特征。
---------------------------------多态----------------------------------------------------------
什么是多态? 多种状态
如何产生多态? 继承多态 父类的引用 子类的对象 例如 : Animal a = new Dog(); 基本上不用
接口多态 接口的应用 实现类的对象 例如: IStudentDAO dao = new StudentDAOImpl();
为什么要使用多态? 程序解耦 解除程序的耦合性
--------------------------------------------------------------------------------------------------
B 接口声明的方法(接口中该写哪些方法)
重要:根据业务需求 / CRUD 增删改查
接口代码:(声明方法)
/**接口命名规则:
*创建接口IStudent.I代表这是一个接口,Student代表对应业务的名称(表名),DAO后缀,表明当前是一个DAO接口
*/
public interface IStudentDAO { /*1.添加新学生
* sql语句insert into Student (name,age) values(?,?);
* @param是学生对象,里面存放着需要添加的学生信息
* @return的boolean类型,成功返回true,失败返回false
* 注意:两个以上的参数,使用对象传参。如该例子的Student
* */
boolean add(Student s);
/*2.根据id删除学生
* sql语句:delete from Student where id=?;
* */
boolean delete(int id);
/*3.根据id修改学生
* sql语句:update Student set name=? ,age=? where id=?;
* */
boolean update(Student s);
/*4.根据id查询学生
* Map是一个key value的键值映射
* java类型接收:一个返回值类型,返回id name age三个数据
* 对象接收:Student s=new Student();
* s.setId();s.setName();s.setAge();
* 多态:Map map=new HashMap();
* map.put("id", );map.put("name", );map.put("age", );
* */
Map<String ,Object> getStudent(int id);
/*5.查询所有的学生*/
List<Map<String ,Object>> getAllStudent();
}
实现类代码:(对方法完成实现)
//删除
@Override
public boolean delete(int id) {
String sql = "delete from student where id = ?";
return DBUtil.executeUpdate(sql,id);
}
//修改
@Override
public boolean update(Student s) {
String sql = "update student set name=?,age=? where id = ?";
return DBUtil.executeUpdate(sql,s.getName(),s.getAge(),s.getId());
}
//查询,结果封装成map(只能查一条)
@Override
public Map<String, Object> getStudent(int id) {
String sql="select * from student where id=?";
List<Map<String, Object>> list = DBUtil.executeQuery(sql, id);
System.out.println(list);
if (list.size()>0){
return list.get(0);
}
return null;
}
//查询,多条map放进list集合中
@Override
public List<Map<String, Object>> getAllStudent() {
String sql="select * from student";
return DBUtil.executeQuery(sql);
}
}
4 接口中 声明 五个方法 (一个方法:返回值 参数 试想一下 这个业务的sql )
A 添加新学生
B 根据id删除学生
C 根据id修改学生
D 根据id查询学生
E 查询所有学生
5 对方法完成实现
6 测试代码
代码分层之模拟servlet调用dao的更多相关文章
- 简单servlet调用dao层完整步骤
导入包lib(文件名称) 目录结构:web下:views.web-inf.index.jsp views下各种jsp文件和js(里面放封装好的jquery包) js下:jquery包(js文件后缀) ...
- jsp+servlet+javaBean+Dao
一.Servlet程序各模块介绍1.JSP 用于显示.收集数据的部分.2.Servlet 用于验证数据.实例化JavaBean.调用DAO连接数据库.控制页面跳转3.DAO 用于连接数据库及进行数据库 ...
- Servlet里面一调用Dao里的某个方法
背景: 这几天,由于项目集成的需要,我要在doFilter里调用dao层里的某些方法,可是总之报空指针,只要调用那个dao方法,就报错误.很是纳闷,网上查找了各种原因,终于让我给突破了,看来还是Jav ...
- 使用XWAF框架(1)——Web项目的代码分层
建议在Eclipse环境下使用XWAF框架来开发用户的Web项目,并遵循以下步骤和约定. 1.获取XWAF框架压缩包文件 程序员点击下列地址免费下载XWAF框架的压缩包文件:XWAF框架压缩文件 2. ...
- C#7.2——编写安全高效的C#代码 c# 中模拟一个模式匹配及匹配值抽取 走进 LINQ 的世界 移除Excel工作表密码保护小工具含C#源代码 腾讯QQ会员中心g_tk32算法【C#版】
C#7.2——编写安全高效的C#代码 2018-11-07 18:59 by 沉睡的木木夕, 123 阅读, 0 评论, 收藏, 编辑 原文地址:https://docs.microsoft.com/ ...
- asp.net 模拟CURL调用微信公共平台API 上传下载多媒体文
近公司项目上在开发微信服务号的接口,需要给用户回复图片或语音或视频,这个时候就需要用到 上传下载多媒体文件接口,微信在这方面推荐采用的是开源函数库curl实现的,CURL项目包括很多版本,我主要测试的 ...
- setTimeout模拟setInterval调用
在开发环境下,尽量不用间歇调用,原因是后一个间歇调用可能会在前一个间歇调用结束之前启动. 尽量使用超时调用来模拟间歇调用. 示例代码: <!DOCTYPE html> <html l ...
- 我们自己写的solr查询的代码作为search项目中的dao
我们自己写的solr查询的代码作为search项目中的dao,但是启动时会报错: 其实就是说 searchServiceImpl 中我们 Autowired 的 SearchDao 类 spring ...
- asp.net 模拟CURL调用微信公共平台API 上传下载多媒体文件接口
FormItem类 public class FormItem { public string Name { get; set; } public ParamType ParamType { get; ...
随机推荐
- JavaScrip(一)JavaScrip的写法
一:如何写JavaScript 1.直接写入 <scricp type="text/javascricp >*********</scricp> 直接写到标签里面. ...
- NIO完成网络通信(一)
NIO:即非阻塞式IO 视频教程: https://chuanke.baidu.com/v1982732-211322-1316084.html 使用步骤: 1.创建 ServerSocketCha ...
- springmvc添加拦截器
springmvc.xml配置如下: 除了 sysFile 下的所有接口,以及user下的loginUser接口,其他的所有接口都会经过拦截器UserInterceptor处理 <mvc:int ...
- 解决NPM无法安装任何包的解决方案(npm ERR! code MODULE_NOT_FOUND)
前言 今天突然发现npm无法使用了,执行任何命令都报如下错误: npm ERR! code MODULE_NOT_FOUND npm ERR! Cannot find module 'internal ...
- git 继续前进篇
* git 输入 git log (--all)命令后出现<END>标记? 按q退出历史记录列表即可 * 继续前一天的 继续推送到github 步骤看图 先 链接到 之前工作区 的 文 ...
- shell脚本实例-批量检查多个网站地址是否正常
#!/usr/bin/bash [ -f /etc/init.d/functions ] && . /etc/init.d/functions array=( http://www.w ...
- python DRF操作流程
# 其实就是Django RESTful Framework # RESTful一种API的命名风格,主要因为前后端分离开发出现 # 前后端分离: 用户访问静态文件的服务器,数据全部由ajax请求给到 ...
- python day16--面向对象(01)
一.概念 类:具有相同属性的一类事物 比如人类是类,人类中的某个人是对象.食物是一类,米饭是一个对象 class Person: '''类体:两部分:变量部分,方法(函数)部分''' mind = ' ...
- 引用google字体
1.很简单直接 @import url(http://fonts.font.im/css?family=Shadows+Into+Light); 引入页面即可 2. 使用: font-fami ...
- HTTP Security Header Not Detected未检测到HTTP安全标头
遇到此安全问题,只需修改Web.config文件. 如: 未处理之前配置代码如下: <httpProtocol> <customHeaders> <add name=&q ...