文档章节

基于表单的投票系统--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
PHP最佳实践

今天下午,我在读下面这篇文章。 虽然名字叫《PHP最佳实践》,但是它主要谈的不是编程规则,而是PHP应用程序的合理架构。 它提供了一种逻辑和数据分离的架构模式,属于MVC模式的一种实践。我...

阮一峰
2010/12/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CentOS7.4 搭建 ss

一键安装 shadowsocks-go 版 wget –no-check-certificate https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/shadowsocks-go.sh chmod +x shadowsocks-go.sh ./s......

YunOu
32分钟前
5
0
Spark Streaming整合kafka实战

kafka作为一个实时的分布式消息队列,实时的生产和消费消息,这里我们可以利用SparkStreaming实时计算框架实时地读取kafka中的数据然后进行计算。在spark1.3版本后,kafkaUtils里面提供了两个...

hblt-j
32分钟前
2
0
vue组件中的样式属性scoped实例

vue组件中的style标签标有scoped属性时表明style里的css样式只适用于当前组件元素 。接下来通过本文给大家分享vue组件中的样式属性scoped实例详解 **Scoped CSS** Scoped CSS规范是Web组件产...

前端攻城老湿
48分钟前
4
0
ios 面试部分整理

assign weak区别 assign不是有崩溃的风险么 strong和copy 对非容器类可变类型 非容器类不可变 容器类可变容器类不可变 进行深拷贝浅拷贝有什么区别 什么样的对象可以进行拷贝 就是这个NScod...

大魔王周晓辉
49分钟前
2
0
浅谈教你如何掌握Linux系统

linux能做什么?相信绝大数人都有这样的疑问。可以玩吃鸡吗?可以玩lol吗? 如果你是以娱乐的名义来评价linux的可用性,对不起,linux可能不适合你,因为linux是一个工具,他是教你聪明的,不...

Linux就该这么学
49分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部