开发者社区> 技术mix呢> 正文

数据库中的记录通过servlet回显到jsp页面中(连接数据库或者查询參照:对数据进行增删改查)

简介:
+关注继续查看

        我们常常会用到通过图书的名称来查询图书那么这种话我们也就会使用到从数据库中搜索出数据而且载入到自己的Jsp页面中

           这种话我们须要将从数据库中获取到的数据放进响应中然后通过%=request.getAttribute("bookId1") %获取对应的值当然仅仅有servlet和jsp页面是不够的还须要的是将你的servlet配置到你的wed.xml中。这样你的servlet才干够使用。

          下面为个人浅浅的想法:事实上我个人认为动态的载入网页更加的简单比如:你想要在你的站点每天公布一张站点动态图片那么你须要做的就是最简单的方式将你的图片命名成之前的名称用以替换然后单独的一个文件存放文本文件 再将文本文件载入进来另一种更加安全的方法就是你须要将你的文件放进数据库中然后在每次訪问页面时候通过servlet载入进来(个人认为这样的方式尽管安全可是载入的比較慢一般人都不愿去等待)另一种就是我记得老师和我说过有一种专用的站点后台管理的假设创建自己的站点能够考录是用那个。

中间使用的book是定义的一个book类存储的是book的基本信息为其设置setter和getter訪问器这种话符合封装原则


package bookConnUtil;



import java.io.IOException;
import java.sql.SQLException;


import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


public class selectBook extends HttpServlet {
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
// TODO Auto-generated method stub

String bookId=req.getParameter("bookId");

try {

//本句话调用的是等会数据库进行增删改查里的一个static方法可參考我写的:http://blog.csdn.net/bluezhangfun/article/details/46617455

boolean flag=bookDAO.bookSelete(bookId);

//进行调试的语句

//System.out.println("bookSelect方法正常!!

!。。!!

。!!

。!

");

if(flag==true){

//book.getBookID();在以下类中

String bookId1=bookDAO.book.getBookID();
String bookName=bookDAO.book.getBookName();
String pianduanName=bookDAO.book.getPianduanName();

//System.out.println(bookId1+"+++++++++++++++++++++++++++");

//将从数据库中查询到的语句放入到response中

req.setAttribute("bookId1", bookId1);
req.setAttribute("bookName", bookName);

req.setAttribute("pianduanName",pianduanName);

//进行页面跳转

req.getRequestDispatcher("selectBook.jsp").forward(req, resp);

}else{
req.getRequestDispatcher("error.html").forward(req, resp);

}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

}

/***************************************************************************************************************************

package bookConnUtil;


import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;


import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//使用rs结果集的时候由于查询的是一条语句  假设是使用rs.next就是没有后继所以就不能运行while循环将会出现错误 
//假设是查询的多条语句结果是多条的话那么就能用while循环这样就能实现反复的输出
//使用prepareStatement时候必须先要对当中的?号进行赋值不然会出现错误的
public class bookDAO{
static books book = new books();
 public static books getBook(){
 return book;
 }
public static boolean bookSelete(String bookId) throws SQLException{
String updateWithUid ="select bookId,bookName,pianduanName from books where bookId=?"; 
//String updateWithUname ="update users set UID=?

,password=?

,email=?,utype=?where Uname=?";
 

boolean flag =true;

Connection conn=null;
PreparedStatement stmt=null;
ResultSet rs=null;
try{
conn=DBUtil.getConnection(DBUtil.CONNECTION_SQL);

stmt=conn.prepareStatement(updateWithUid);
stmt.setString(1,bookId);
System.out.println("bookId是"+bookId+"!!!!!!!!!!!!");

rs=stmt.executeQuery();

if(rs.next()==false){flag=false; return flag; }


System.out.println("没有进入到循环中+++++++++++++++++++++");
String bookId1 = rs.getString(1);
System.out.println(bookId+"++++++++++++++++++");
book.setBookID(bookId1);
String bookName = rs.getString(2);
book.setBookName(bookName);
System.out.println(bookName+"++++++++++++++++++");
String pianduanName = rs.getString(3);
book.setPianduanName(pianduanName);



return flag;

}catch(Exception e){
e.printStackTrace();
}finally{
conn.close();
stmt.close();

}
return false ;
}





}/

/**********************************************************************************************************************************************/

以下的代码是对response中的数据提取并显示在页面中我仅仅做了简单的处理

假设嫌自己的页面过于简单或者是运行的功能过于单一那么在jsp或者是你的servlet中进行控制

<div class="form_row">
            <label class="contact"><strong>书籍ID:</strong></label>
            <input type="text" class="contact_input" name="bookId" value='<%=request.getAttribute("bookId1") %>'/>
          </div>
          <div class="form_row">
            <label class="contact"><strong>书籍名称:</strong></label>
            <input type="text" class="contact_input" name="bookName" value='<%=request.getAttribute("bookName") %>'/>
          </div>
          <div class="form_row">
            <label class="contact"><strong>片段信息:</strong></label>
            <input type="text" class="contact_input" name="pianduanName" value='<%=request.getAttribute("pianduanName") %>' />
          </div>






本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5256073.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
数据库&nbsp;连接&nbsp;查询
数据库&nbsp;连接&nbsp;查询
24 0
MySQL 基础---单表数据记录查询
**查询数据记录操作: ** 简单数据记录查询 条件数据记录查询 排序数据记录查询 限制数据记录查询 统计函数和分组数据记录查询 测试表 # 创建雇员表 create table t_employee( empno int(1...
820 0
EMR Spark Relational Cache 利用数据预组织加速查询
本文介绍了EMR Spark的Relational Cache如何从数据量较大的Cube中快速提取出所需数据加速查询的原理。通过列式存储、文件索引、Z-Order等技术,我们可以快速过滤数据,大大减少实际发生的IO数据量,避免IO瓶颈的出现,从而优化整体查询性能。
990 0
你会不会用mysql查询近7个月的数据?没有记录默认为空
你会不会用mysql查询近7个月的数据?没有记录默认为空
31 0
oracle通过job定时执行任务
2013年8月27日 星期二 20:49 在项目中,经常会遇到需要定时完成的任务,比如定时更新数据,定义统计数据生成报表等等,其实这些事情都可以使用Oracle的Job来完成。下面考试大就结合我们实验室项目实际,简单介绍一下在Oracle数据库中通过Job完成自动创建表的方法。   整个过程总共分为两步。虽然整个过程都非常简单,但是对于初学Oracle的生手还是有很多地方需要注意的。
1714 0
SQL Server 2000删除表中的重复记录
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/chinahuyong/article/details/3551849  在SQL Server中除了对拥有十几条记录的表进行人工删除外,实现删除重复记录一般都是写一段代码,用游标的方法一行一行检查,删除重复的记录。
670 0
asp.net frameset 框架页面伸缩功能实现
1、新建Left.aspx、Right.aspx和Top.aspx页面 2、新建一个index.
809 0
+关注
2968
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载