1、DAO模式 分包:依次建立

entity:实体包,放的是跟oracle数据库中表结构相对应的对象的属性,也就是这个对象有什么

dao:增删改查接口,实现增删改查的具体方法

service:同dao,也是一个接口,一个接口的实现类,方法什么的都跟dao差不多

servlet:新建servlet类,继承HttpServlet类,一个方法建立一个servlet类,根据不同的方法选择使用doGet()、doPost()方法 、services()既包含doGet 又包含doPost

新建jsp页面

这些都是新建web项目

2、save方法,对应sql语句insert into

数据原型是干啥使的,当用户要存入一条新纪录时,用户在jsp页面输入,在servlet获得,存入实体对象,调用service层的save方法,service层再return给dao层

,再往数据库插入

3、update更新数据方法跟add差不多。比add还要简单多了,直接拿到id调用update方法,就会返回一个完整的实体对象,把实体对象存到作用域,转发给edit.jsp;

不同点:在jsp页面需要回填数据到表单    用el表达式


分页查询功能

java中万物皆对象,在util包中新建个pageBean对象,包含pageIndex页号、List  results 查询结果集、rowCount总行数/pageSize每页行数=pageCount总页数

在dao层写接口。也叫find方法,传参pageIndex页号(在servlet层给出初始值,在jsp层需要用户传入)、pageSize每页行数(在servlet层给规定每页显示几个)、  模糊查询搜索字段名(表中的)(需要用户给)

写实现类。先连接数据库,先执行查询所有记录数的sql语句,得到总页数与首尾行号

如果为true则再执行分页的sql语句,从结果集中取出来封装到book实体类,再封装pageBean对象

dao层负责想方设法从数据库得到数据;servlet层负责从jsp拿到数据,转发或重定向到jsp

下面来说说servlet层:先考虑是doGet还是doPost,doGet是想查询数据,搜索框,所以得先解决中文乱码,先设pageIndex=1,pageSize=2,判断浏览器是否传页号

a、数据分页查询

b、数据分页显示

复习步骤先从数据库开始,sql语句,jdbc将java程序与数据库连接起来,可以使java程序操作数据库中的数据

由底层开始,层层往上,最后一直到jsp显示层

1、sql语句

count()聚合函数    计总行数

row_number() over (partition by deptno order by sal desc)分区子句按部门编号分区,把查询结果分为不同的组,类似于group by;排序子句,将每个分区排序。为查询结果分配行号

order by desc 降序/ asc 升序 默认

select * from  book  查询book表中 的所有列

select 结果分配行号,book表中的所有列 from book where title like ?

select row_number() over (order by id desc) as rnbook表中的所有列 from book  b where title like ?

列名起别名是as 名字   表名起别名 是直接名字即可

把表中所有列查询结果都分配行号,id降序,模糊查询

select t.*
from(select  ROW_NUMBER() OVER(order by id desc) as rn,b.*
        from book  b
        where title like '%a%') t
where t.rn between 2 and 14;

按照查询条件把我想要的所有行显示出来了,但是我想分页显示,就要设置每一页显示的首尾行号,这样就能确保每一页准确无误的显示了

查询步骤

1、先获得符合查询条件的总行数

select count(*) as count from Book where title like '%a%';

把sql语句where like 查询条件变成一个搜索栏,新建一个pageBean对象用来显示分页情况

先和数据库建立连接,执行sql语句,得到总行数,求出总页数,pageIndex 和pageSize servlet层会先给个默认值的

设置每页首尾行号

2、再执行一次sql语句

开始分页了

从数据库里把数据取出来(结果集)DAO----->Entity放到对象中啊,集合中啊         service层返回DAO层           service----->servlet<-----jsp

3、servlet层

在list页面调用分页查询方法

因为需要用户传参,所以就得先做非空判断

在servlet层,只要转发就写的是xxx.jsp

只要重定向就是“list”  response.sendRedirect("list");

4、index.jsp

搜索栏

URL开头的斜线总结

1.在HTML标签中设置src属性、href属性时
开头的"/"代表服务器根目录(web-apps)   Tomcat目录结构,web应用发布目录

2.在配置Servlet或进行转发时
开头的"/"代表项目的WebRoot目录

3.在重定向时,开头的"/"代表服务器根目录(web-apps)

转发重定向时的路径问题:

转发时的路径,基本都是xxx.jsp页面,因为有数据要转发到页面然后显示给用户看

重定向时路径有两种情况:a.退出登陆直接重定向到login.jsp页面;注册成功后重定向到login.jsp页面;路径都是同一级的

b.登陆成功后要访问后台background/list;添加成功后要

web项目总结——通过jsp+servlet实现对oracle的增删改查功能的更多相关文章

  1. JSP+Servlet+JavaBean实现数据库的增删改查

    基本思想:JSP文件显示页面,使用form或href超链接传值到Servlet中方法,在Servlet方法中调用Dao层的类对象,实现对数据库里的数据的增删改查,之后重新返回到JSP输出操作完的结果. ...

  2. Android 利用xUtils框架实现对sqllite的增删改查

    首先下载xUtils,下载地址:https://github.com/wyouflf/xUtils  把下载好的文件压缩,把里面的jar包拷进项目中如图所示: 这里新建一个User类进行测试增删改查 ...

  3. Javaweb实现对mongodb的增删改查(附带源代码)

    运行截图: 删除后的信息 项目源代码:https://www.cnblogs.com/post/readauth?url=/zyt-bg/p/9807396.html

  4. 在Salesforce中实现对Object的增删改查操作

    1): Insert Statement    http://www.salesforce.com/us/developer/docs/apexcode/index_Left.htm#CSHID=ap ...

  5. 实现对sqlite数据库增删改查

    package com.example.db.dao;import java.util.ArrayList;import java.util.List;import android.content.C ...

  6. Java实现对cookie的增删改查

    原文地址:http://blog.csdn.net/k21325/article/details/54377830 @RequestMapping(value="meeting/addGua ...

  7. mvc模式jsp+servel+dbutils oracle基本增删改查demo

    mvc模式jsp+servel+dbutils oracle基本增删改查demo 下载地址

  8. mvc模式jsp+servel+jdbc oracle基本增删改查demo

    mvc模式jsp+servel+jdbc oracle基本增删改查demo 下载地址

  9. python web.py操作mysql数据库,实现对数据库的增删改查操作

    使用web.py框架,实现对mysql数据库的增删改查操作: 该示例代码中连接的是本地数据库testdb,user表,表结构比较简单,只有两个字段:mobile和passwd,类型均为字符型 实际应用 ...

随机推荐

  1. 28个Unix/Linux的命令行神器_转

    28个Unix/Linux的命令行神器 下面是Kristóf Kovács收集的28个Unix/Linux下的28个命令行下的工具,有一些是大家熟悉的,有一些是非常有用的,有一些是不为人知的.这些工具 ...

  2. Nginx location 匹配顺序整理

    Nginx location模块整理 具体的Nginx安装就不在这里描述了,这里只是为了对location的描述 Nginx环境 a. 查看当前系统cat /etc/redhat-release [r ...

  3. ios-将代码创建的视图控件放入拖拽控件的下面

    如图所示 图片是拖拽上去的imageView,橘黄色控件是在代码中创建的添加上去的,此时黄色view在imageView 上方 调用方法bringSubviewToFront:试图将imageView ...

  4. MWeb 2.0.7 版发布!

    更新前针对 MAS 上的评论重点说一下:MWeb 是支持直接对本地文件夹操作的,不用导入到文档库!请使用外部模式!请使用外部模式!!请使用外部模式!!! 重要的话讲三次!使用方法是 CMD + E 打 ...

  5. struts---JSP界面验证码生成与验证

    之前想做一个随机验证码的功能,自己也搜索了一下别人写的代码,然后自己重新用struts2实现了一下,现在将我自己实现代码贴出来!大家有什么意见都可以指出来! 首先是生成随机验证码图片的action: ...

  6. 【002:ESP8266 移植 Mqtt 】

    系统环境: ubuntu 16.04 64bitSDK版本: esp_iot_sdk_v1.3.0记录时间: 2016年10月13日联系方式: yexiaopeng1992@126.com 背景:在E ...

  7. YbSoftwareFactory 代码生成插件【二十一】:Web Api及MVC性能提升的几个小技巧

    最近在进行 YbSoftwareFactory 的流程功能升级,目前已经基本完成,现将用到的一些关于 Web Api 及 MVC 性能提升的一些小技巧进行了总结,这些技巧在使用.配置上也相当的简单,但 ...

  8. python之编写三层菜单(第一天)

    作业三:多级菜单 三级菜单 可依次选择进入各子菜单 所需新知识点:列表.字典 针对此菜单程序的设计,使用了yaml格式的文本,由python对其内容进行解析为多重字典,然后对字典进行遍历,判断并输出三 ...

  9. ASP.NET 发布到IIS后支撑woff 的解决方案

    <system.webServer>    <staticContent>        <remove fileExtension=".woff" ...

  10. 设置Beyond Compare 为 Git 默认的比较工具

    对于Beyond Compare4,Git版本号在2.2.0之后的,请在Git中依次输入以下命令: git config --global diff.tool bc3 git config --glo ...