文档章节

基于表单的投票系统--MySql ,DAO ,VO

c
 chuiyuan
发布于 2014/06/13 19:57
字数 510
阅读 601
收藏 6

一。系统分析 

     只要一个界面 ,但是建议写两个,一个用于显示投票界面 ,一个用于接受用户的投票,将所对应的老师得票加1 ,

工作完了再回到前一个界面 。

各个页面与作用:

VoteDao.java     连接数据库,查询老师的编号 ,姓名 ,得票,修改老师的得票数,将编号对应的得票 数加  1

Vote.java          封装老师的编号 ,姓名 ,得票 数

display.jsp        调用VoteDao查询老师编号 ,姓名 ,得票数,并显示

vote.jsp            获得request 传送 过来的老师编号数组  ,调用 VoteDao 将每个编号对应的得票数加1 ,回到display.jsp 

二。数据库初始化

属性:teacherno   teachername   votenumber 

在mySQL中写成脚本运行,用source 命令。

use test;
create table t_vote(
 teacherno varchar(20),
 teachername varchar(20),
 vote int );
insert into t_vote values('1', 'lishengjing',1);
insert into t_vote values('2', 'huangwenjun',1);
insert into t_vote values('3', 'zhaosy',2);
insert into t_vote values('4', 'chaoshehn',3);

三。java 代码 

        要将MySQL的驱动复制到 web-inf/lib中,将bar.jpg 复制到WebRoot下的img目录。导入包时最好用 import java.sql*;

public class VoteDao {
	private Connection  conn=null;
	
	public void initConnection() throws Exception{
		Class.forName("com.mysql.jdbc.Driver");
		String url ="jdbc:mysql://localhost:3306/test";
		conn = DriverManager.getConnection(url , "root","root");
		
	}
	
	public ArrayList getAllVotes()throws Exception{
		ArrayList all = new ArrayList ();
		initConnection();
		String sql = "select * from t_vote";
		Statement stat= conn.createStatement();
		ResultSet rs = stat.executeQuery(sql);
		
		while (rs.next()){
			Vote vote = new Vote();
			vote.setTeacherno(rs.getString("teacherno"));
			vote.setTeachername(rs.getString("teachername"));
			vote.setVotenumber(rs.getInt("vote"));
			all.add(vote);
		}
		clossConnection();
		return all;
		
	}
	
	public void updateVotes(String [] teacherno )throws Exception{
		initConnection();
		String sql = "update t_vote set vote=vote+1 where teacherno=?";
		PreparedStatement ps = conn.prepareStatement(sql);
		
		for (int i =0;i<teacherno.length;i++){
			ps.setString(1, teacherno[i]);
			ps.executeUpdate();
		}
		clossConnection();
	}
	
	public void clossConnection ()throws Exception{
		conn.close();
	}
}


四。JSP代码部分

display.jsp

<body>
    <form action ="vote.jsp"  method ="post">
		<table align="center">
			<caption>
				欢迎投票<input type="submit" value="提交">
			</caption>
			<tr bgcolor="yellow">
				<td>编号</td>
				<td>姓名</td>
				<td>得票数</td>
			</tr>

			<%
				VoteDao vdao= new VoteDao();
			    ArrayList votes = vdao.getAllVotes();
			    for (int i=0;i<votes.size();i++){
			    Vote vote =(Vote) votes.get(i);
			%>
			<tr bgcolor="pink">
				<td><%=vote.getTeacherno()%></td>
				<td><%=vote.getTeachername()%></td>
				<td><img src ="img/bar.jpg"  width="<%=vote.getVotenumber() %>"  height ="10"/>
				<%=vote.getVotenumber() %></td>
				<td><input name="teacherno" type="checkbox"
					value="<%=vote.getTeacherno()%>"></td>
			</tr>
			<%
				}
			%>

		</table>
	</form>
  </body>

vote,jsp

 <body>
    <% 
    String [] teacherno = request.getParameterValues("teacherno") ;
    VoteDao vdao = new VoteDao();
    vdao.updateVotes(teacherno);
    %>
    <jsp:forward page="display.jsp"></jsp:forward>
  </body>




© 著作权归作者所有

共有 人打赏支持
c
粉丝 9
博文 92
码字总数 40993
作品 0
海淀
dao设计模式

具体内容 DAO:数据访问对象:Data Acess Object,即:使用对象的形式操作数据库。 DAO组成: VO:每一个VO对象可以表示出一张表单一行记录,此类的名称要与表单名称一致。 DAO:操作接口:每...

李茂冉
2016/05/18
31
0
开源平台eRedG4_V1.2版发布了

在广大网友的支持和鞭策下,eRedG4_V1.2版又登场了。 eRedG4(易道系统集成与应用开发平台)是一个开放源代码的、面向企业计算环境下异构系统集成与行业应用快速二次开发的平台。它包括:基础类...

Google
2011/05/04
2.9K
0
留言管理V1.0

1、需求分析 1.1、用例分析:主要是分析整个系统的功能。 基于用户管理功能的用例 基于留言管理的用例 1.2、类图分析:在用例的基础上来分析需要存在哪些对象。 1.3、创建ER图:可以直接根据...

pmos
2016/09/02
30
0
VO(DTO)模式在架构设计中是否需要

最近在做自己的博客后台设计,用的是Jodd,我大jodd V587!!! 以前的公司在做一个项目时,会定义很多概念:VO,BO,PO什么的。。。。。。。 引文 大多数的应用,基于分层架构的: Web层(S...

青木河
2014/06/26
3.2K
8
10 个有意思的 PHP 教程

今天我为大家挑选了 10 个关于 PHP 的教程,设计到 pChart、投票、图片过滤、facebook 连接器等等,希望对你有用。 1. pChart Revisited with Google Analytics 在这篇文章中你将学习如何使用...

红薯
2012/04/19
4.4K
5

没有更多内容

加载失败,请刷新页面

加载更多

如何通过 J2Cache 实现分布式 session 存储

做 Java Web 开发的人多数都会需要使用到 session (会话),我们使用 session 来保存一些需要在两个不同的请求之间共享数据。一般 Java 的 Web 容器像 Tomcat、Resin、Jetty 等等,它们会在...

红薯
今天
3
0
C++ std::thread

C++11提供了std::thread类来表示一个多线程对象。 1,首先介绍一下std::this_thread命名空间: (1)std::this_thread::get_id():返回当前线程id (2)std::this_thread::yield():用户接口...

yepanl
今天
3
0
Nignx缓存文件与动态文件自动均衡的配置

下面这段nginx的配置脚本的作用是,自动判断是否存在缓存文件,如果有优先输出缓存文件,不经过php,如果没有,则回到php去处理,同时生成缓存文件。 PHP框架是ThinkPHP,最后一个rewrite有关...

swingcoder
今天
2
0
20180920 usermod命令与用户密码管理

命令 usermod usermod 命令的选项和 useradd 差不多。 一个用户可以属于多个组,但是gid只有一个;除了gid,其他的组(groups)叫做扩展组。 usermod -u 1010 username # 更改用户idusermod ...

野雪球
今天
3
0
Java网络编程基础

1. 简单了解网络通信协议TCP/IP网络模型相关名词 应用层(HTTP,FTP,DNS等) 传输层(TCP,UDP) 网络层(IP,ICMP等) 链路层(驱动程序,接口等) 链路层:用于定义物理传输通道,通常是对...

江左煤郎
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部