基于表单的投票系统--MySql ,DAO ,VO_MySQL
一。系统分析
只要一个界面 ,但是建议写两个,一个用于显示投票界面 ,一个用于接受用户的投票,将所对应的老师得票加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" style="max-width:90%"基于表单的投票系统--MySql ,DAO ,VO_MySQL" >" 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>

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

記事では、MySQLで大規模なデータセットを処理するための戦略について説明します。これには、パーティション化、シャード、インデックス作成、クエリ最適化などがあります。

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

この記事では、ドロップテーブルステートメントを使用してMySQLのドロップテーブルについて説明し、予防策とリスクを強調しています。これは、バックアップなしでアクションが不可逆的であることを強調し、回復方法と潜在的な生産環境の危険を詳述しています。

記事では、外部キーを使用してデータベース内の関係を表すことで、ベストプラクティス、データの完全性、および避けるべき一般的な落とし穴に焦点を当てています。

この記事では、クエリパフォーマンスを強化するために、PostgreSQL、MySQL、MongoDBなどのさまざまなデータベースでJSON列にインデックスの作成について説明します。特定のJSONパスのインデックス作成の構文と利点を説明し、サポートされているデータベースシステムをリストします。

記事では、準備されたステートメント、入力検証、および強力なパスワードポリシーを使用して、SQLインジェクションおよびブルートフォース攻撃に対するMySQLの保護について説明します。(159文字)
