文档章节

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

c
 chuiyuan
发布于 2014/06/13 19:57
字数 510
阅读 603
收藏 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
留言管理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.5K
8
开源平台eRedG4_V1.2版发布了

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

Google
2011/05/04
3K
0
PHP最佳实践

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

阮一峰
2010/12/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

springboot2.0 rabbitmq

AmqpTemplate接口没有参数说明,不知道传啥参数,这是很难受,不知道怎么看参数的定义.... 1、先来添加引用包 <dependency> <groupId>org.springframework.boot</groupId> <artifa......

朝如青丝暮成雪
18分钟前
1
0
replace File.separator出现异常:【java.lang.IllegalArgumentException: character to be escaped is missing】

写代码时,要写这么一个功能:将包名中的"."换成路径分隔符("/"或"",视操作系统而定),要求在window或linux下都能正常运行。 分析一下,这明显是个字符串替换的操作,可用使用String提供的...

Funcy1122
19分钟前
1
0
centos7下查找项目路径

1、查出tomcat的端口(如已知端口请忽略,其实用该命令也可以查出tomcat的位置,项目太多,不想找的话,就用下面的步骤吧。) ps -aux | grep tomcat 2、根据端口号查询进程,并获取进程ID ...

You_are_my_music
22分钟前
1
0
微信小程序与原生的App(iOS、Android)的优势对比

小程序也属于App的一种,那么它和我们现在流行的原生App(IOS、Android)相比,有什么区别和优势呢? 一、区别与优势 首先,从技术上来讲,目前App的主流开发方式有三种:Web App 、Native ...

Mr_ET
24分钟前
5
0
第二篇:SpringBoot接口Http协议

1、SpringBoot HTTP请求配置 简介:SpringBoot2.xHTTP请求注解讲解和简化注解配置技巧 1、@RestController and @RequestMapping是springMVC的注解,不是springboot特有的 2、@RestController...

嘴角轻扬30
25分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部