Web Developer's Virtual Library: Encyclopedia of Web Design Tutorials, Articles and Discussions


WDVL Newsletter

Active Server Pages
JSP/Java Servlets
Microsoft SQL Server
Daily Backup
Dedicated Servers
Streaming Audio/Video
24-hour Support    

jobs.webdeveloper.com

Hiermenus


e-commerce
Partner With Us















Developer Channel
FlashKit.com
JavaScript.com
JavaScriptSource
Developer Jobs
ScriptSearch
StreamingMediaWorld
Web Developer's Journal
Web Developer's Virtual Library
WebDeveloper.com
Webreference
Web Hosts
XMLfiles.com

internet.com
IT
Developer
Internet News
Small Business
Personal Technology

Search internet.com
Advertise
Corporate Info
Newsletters
Tech Jobs
E-mail Offers


The Birth of a Poll - Page 3

January 8, 2001

Beginning the Poll Code

Over the next few pages we are going to deal with coding this poll so that it actually does something that works. The code is going to get fairly long but I will attempt to keep it as brief as possible. Please remember that long code does not mean complicated code - the logic is fairly simple once you get the gist of everything that is going on.

The first thing you need to do is establish a connection to the database, like so:

dim Conn, rs_Questions, rs_Responses

set Conn = Server.CreateObject("ADODB.Connection")
Conn.ConnectionString = "dsn=polldb;database=polldb"
Conn.ConnectionTimeout = 60
Conn.CommandTimeout = 60
Conn.Open

set rs_Questions = Server.CreateObject("ADODB.Recordset")
strSQL = "SELECT TOP 1 * FROM tbl_questions " & _
                "ORDER BY PollDate DESC"
rs_Questions.open strSQL, Conn, 3, 3
'TOP 1 returns the topmost record only

'.RecordCount is a method of the ADO Recordset
'for counting the number of records in the set.
recCount = rs_Questions.RecordCount
PollID = rs_Questions("PollID")
PollQuestion = rs_Questions("PollQuestion")
As you can see, we establish a connection via ODBC to the polldb DSN entry on our web server (or personal workstation running Personal Web Server, download it not if you do not have 2000/NT with IIS).

Then we execute a simple SELECT query that returns all the rows in the tbl_questions table. The results of this query are stored in the rs_Questions Recordset. Finally, the records returned by the query are counted using the RecordCount method and stored in a variable named recCount (there is actually not any practical reason to do this here, but I just wanted to show you that you could).

Once we have the database connection established and ready for action, the next step is to start generating the code that will output the form to the client's browser and to begin processing the options for the Poll Question. Since we had our query sort the results by PollDate in descending order, the most recent poll will be the topmost record - which is what we want. That way, there will be no confusion as to which Poll Question to use.

Generating the Poll in HTML with the Appropriate Options

Everything is now in place for us to generate the visual interface for our polling system and to populate it with the options related to the topmost question in the rs_Questions Recordset.

So, the next step is to get a Recordset that contains all the options for our poll in question, and that means another query! This time the query and accompanying ASP looks like:

' Extract the options from the database
strSQL = "SELECT * FROM tbl_Responses " & _
	   "WHERE PollID = " & PollID
set rs_Responses = Server.CreateObject("ADODB.Recordset")
rs_Responses.Open strSQL, Conn, 3, 3

'calculate the total number of responses for the poll
'(you will see why later)
Total = 0
While Not rs_Responses.EOF
Total = Total +  rs_Responses("VoteCount")
	'stores the poll options one per row in a large
	'string of HTML content called PollOptHTML
	PollOptHTML =  PollOptHTML & _
	"<tr><td>" & rs_Responses("PollOption") & _
	"</td><td><input type=""radio""" & _
	"name=""pollopt"" value=""" & _
	rs_Responses("PollOptionID")  & """></td></tr>"
	rs_Responses.MoveNext
Wend
Not hard at all, in fact, very basic stuff. Which leads me to my soapbox: most things that you do with ASP for standard web pages are going to be that simple. Most everything revolves around a core set of knowledge and understanding that can be used time and time again in different situations. If you can master these underlying principles, with time you really will be able to do anything - and it will not have required a degree in Computer Science. On the other hand, a degree in Computer Science surely cannot hurt (aside from all that evil math you have to learn, that does in fact hurt). If you do not understand what was just done in the above code, then I leave the responsibility for finding out on your shoulders. When you are able to learn by dissecting code and then hunting for its meaning, you are well on your way to success.

Updating the Database

Okay, stepping down from my mid-tutorial soapbox, let's move on to some more code. In this block we need to produce the final polling code that handles incoming votes.

strSQL = "UPDATE tbl_Responses " & _
    "SET VoteCount = VoteCount + 1 " & _
    "WHERE PollOptionID= " & _
    Request.QueryString("pollopt") & ";"

'Update the count for the PollOption
'yet another way to run a query against a database
'with ASP Conn.Execute
Conn.Execute strSQL
As you can see, using an SQL UPDATE command we update the tbl_Responses table to reflect the vote for whichever option was selected by the visitor. For future reference, the syntax for the UPDATE command is simple and goes a little like the following (items in brackets are optional):
UPDATE table_name
SET col_name = value
{, col_name2 = value2, col_name3 = value3}
WHERE criteria ;
Finally, let's output the HTML form for this poll assuming this file is named poll.asp for the action. (I will leave making it look pretty to you):
<form name="poll" action="poll.asp" method="get">
<table width="250">
	<tr><td colpan="2">
	<%= PollQuestion %>
	</td></tr>
	<%= PollOptHTML %>
	<tr><td colspan="2">
	<input type="submit" value="Submit Vote">
	</td></tr>
</table>
<input type="hidden" name="isSubmitted" value="yes">
</form>

Where to Start - Page 2
Poll Your Visitors with ASP
A Functional Polling System - Page 4


Up to => Home / Authoring / ASP / Polls




Jupiter Online Media: internet.comearthweb.comDevx.commediabistro.comGraphics.com

Search:

Jupitermedia Corporation has two divisions: Jupiterimages and Jupiter Online Media

Jupitermedia Corporate Info


Legal Notices, Licensing, & Permissions, Privacy Policy.

Web Hosting | Newsletters | Tech Jobs | Shopping | E-mail Offers