Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations Chris Miller on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

adding year,month,date & day to database

Status
Not open for further replies.

lagc

Programmer
Jan 21, 2009
79
GB
Hi all,

I have this simple cms for a client, who wants to add an event to the database using year, month, date & day.

He then wants these events to order themselves when displayed so that 2009 dates fall before 2010, then the month & date, so all nicely in order.

So this is how i thought about going about it:

Code:
<select name="dayDate" id="dayDate">
<option value = "1">Monday</option>
<option value = "2">Tuesday</option>
<option value = "3">Wednesday</option>
<option value = "4">Thursday</option>
<option value = "5">Friday</option>
<option value = "6">Saturday</option>
<option value = "7">Sunday</option>
</select>

The others work in exactly the same way, as in the value.

So once submitted the values go into the database as numbers, then what i am unsure of is how to change that value back day, and the same goes for the others, and also to have it all nicely ordered down the page.

As below:


The example above is using the same principle, but the values are the actualy days, months, dates and years, and thats why it isnt ordering properly.

Any help, will be good, I know its basic stuff, but I need some help please.

Cheers
 
Why not simply add an "eventdate" field in your database (date datatype, not string), rather than separate Year, Month, Day etc fields. When it comes to displaying, use the various VBScript (if that's what you are using) Date functions to get the dates to display exactly as you want.

 
so are you basically trying to convert the number "1" to Monday / "2" to Tuesday ...etc when you post the results back to the screen?

Similarily with months - it's stored as "1" but you want to display "Jan"...

The year is a number anyway, unless you have:

Day: 2
Date: 1
M: 12
Y: 2008

and you want to display it as Tuesday, December 1, two thousand and eight (which I doubt) :)






--------

GOOGLE is a great resource to find answers to questions like "how do i..."


--------
 
Hi yes,

As you can see from the link, I have the events being displayed as day, month, year, and yes as you said because I couldnt get them to order properly, I thought id try the numbers instead, then convert them back, as I thought numbers would order better than text. But obviosuly on display the number would have to change to its corresponding value. 1=monday, 2=tuesday etc.

I have posted the code i am currently using.

Code:
<%
'initialise objects and variables

dim conn, strsql, evuser
set conn=server.createobject("ADODB.Connection")
set evuser=server.createobject("ADODB.Recordset")
strMDBpath = Server.MapPath("users2.mdb")

'direct connection
conn.open "PROVIDER=MICROSOFT.JET.OLEDB.4.0;DATA SOURCE=" & strMDBPath

strsql = "SELECT date_Id, day_date, date_date, month_date, year_date, time_start " &_
"FROM Close_Date " &_
"ORDER BY year_date DESC, month_date DESC, date_date DESC"

evuser.open strsql,conn

%>

I originally tried:

Code:
strsql = "select date_Id, day_date, CDate(day_date&'/'&date_date&'/'&month_date&'/'&year_date) " & _
"from Close_Date ORDER BY CDate(day_date&'/'&date_date&'/'&month_date&'/'&year_date) DESC"

But I couldnt get it to work without getting an error, so i reverted to the easier way.

Then to display the event, its simply:

Code:
<p><%=evuser( "day_date" )%> <%=evuser( "date_date" )%> <%=evuser( "month_date" )%> - Closing at <%=evuser( "time_start" )%></p>

I thought this would be a lot more simpler than it is.

Cheers

 
All you should have to do is grab the "date_date", "month_date" and "year_date" - the day of week is not needed, as "formatDateTime" will take care of that for you.

Order your record set by year desc, month asc, date asc - this will give you the events for the most recent year ordered correctly.

Code:
<%
strsql = "select date_Id, date_date, month_date, year_date from close_date orer by year_date desc, month_date asc, date_date asc";
set rs = myConn.execute(strsql)
	month_date = rs("month_date")
	year_date = rs("year_date")
	date_date = rs("date_date")
	event_date = cdate(month_date & "/" & date_date & "/" & year_date)
	displayDate = formatDateTime(event_date,vblongdate)
	response.write displayDate
	rs.close
set rs  = nothing
%>


--------

GOOGLE is a great resource to find answers to questions like "how do i..."


--------
 
In the sample you originally tried, your CDate(...) includes the day of the week (Monday, Tuesday, etc) which is not correct. Try without it:
Code:
CDate(date_date&'/'&month_date&'/'&year_date)
 
Hi all,

guitarzan i tried yours after trying vicvirk's and neither work. So if you dont mind I will post the code below, and the error.

Code:
<%
'initialise objects and variables

dim strsql, conn, evuser
set conn=server.createobject("ADODB.Connection")
set evuser=server.createobject("ADODB.Recordset")
strMDBpath = Server.MapPath("users.mdb")

'direct connection
conn.open "PROVIDER=MICROSOFT.JET.OLEDB.4.0;DATA SOURCE=" & strMDBPath

strsql = "select date_Id, day_date, CDate(date_date&'/'&month_date&'/'&year_date) "&_
"from Close_Date ORDER BY CDate(date_date&'/'&month_date&'/'&year_date)"

evuser.open strsql,conn

%>

And the error I'm getting for that one is;

Code:
Microsoft JET Database Engine error '80040e07' 

Data type mismatch in criteria expression. 

/earlyCloseing2.asp, line 16

All your code should work guys, i dont get it.
 
All those fields are text fields if that is anything useful

 
Ok the line of code on line 16 is below:

Code:
evuser.open strsql, conn

so i commented it out and the page appeared, but with a different error this time.

Code:
ADODB.Recordset error '800a0e78' 

Operation is not allowed when the object is closed. 

/earlyCloseing2.asp, line 121

which is referring to this code below, which is displaying the data eventually.

Code:
<%
WHILE NOT evuser.EOF
%>	
  <%=evuser( "day_date" )%>&nbsp;<%=evuser( "date_date" )%>&nbsp;<%=evuser( "month_date" )%> - Closing at <%=evuser( "time_start" )%>
<%
evuser.MoveNext
Wend
%>
<%
'close resources used
evuser.close
'conn.close

'clean up
set evuser=nothing
'set conn=nothing
%>

And that error is referring to this piece of code

Code:
<%
WHILE NOT evuser.EOF
%>

So by commenting out that line of code, i dont get the errors in the cdata code, so there must be something wrong on line 16 which i dont know im sorry
 
Ok ive worked out whats causing the problem, and its this bit:

Code:
date_date &'/'&

I took it away and it worked, but then I had the issue of what do I use to display that data as its inside cdata.

is the use of the word date causing the problem?
 
> ... its this bit: "date_date &'/'&" ...I took it away and it worked

So your CDate() only has month/year now? That's not going to work if you are trying to get day (and day-of-week) from it.

My advice is, I would try to figure out why you are getting the Data Type mismatch. I would add the error trapping code in blue:
Code:
strsql = "select date_Id, day_date, CDate(date_date&'/'&month_date&'/'&year_date) "&_
"from Close_Date ORDER BY CDate(date_date&'/'&month_date&'/'&year_date)"
[COLOR=blue]On Error Resume Next[/color]
evuser.open strsql,conn
[COLOR=blue]If Err.Number <> 0 Then
   response.write "Got Err#" & Err.Number & :" & Err.Description
   response.write strsql
   response.end
End If
On Error Goto 0[/color]

Now, when the error occurs, you should see the exact SQL statement that was being executed. Pay attention to the CDate() part, and see if it is a valid date inside it or not.

Regarding "what do I use to display that data as its inside cdata", you retrieve the value and use any of the date formatting functions I pointed you to in my first post (such as FormatDateTime as vicvirk mentioned).

For example, add an alias in your sql statement:
Code:
strsql = "select date_Id, day_date, CDate(date_date&'/'&month_date&'/'&year_date) [b]AS EventDate[/b] "&_
"from Close_Date ORDER BY CDate(date_date&'/'&month_date&'/'&year_date)"
...
event_date = evuser("EventDate")
response.write FormatDateTime(event_date,vblongdate)
 
Hi,

Ok Ive sorted the problem out and I dont know get any errors on the page, but only the last entry in the database is displayed on the website.

I'm hoping I havent annoyed anybody too much, but i have the code below in full that im using below, so could somebody have a look to see whay only the last entry is being displayed.

Thanks

Code:
<%
'initialise objects and variables

dim strsql, conn, evuser
set conn=server.createobject("ADODB.Connection")
set evuser=server.createobject("ADODB.Recordset")
strMDBpath = Server.MapPath("users.mdb")

'direct connection
conn.open "PROVIDER=MICROSOFT.JET.OLEDB.4.0;DATA SOURCE=" & strMDBPath
%>

<%
strsql = "select date_Id, day_date, date_date, month_date, year_date from Close_Date order by date_date asc, month_date asc, year_date desc "
set evuser = conn.execute(strsql)
date_date = evuser("date_date")   
month_date = evuser("month_date")    
year_date = evuser("year_date")       
event_date = cdate(date_date & "/" & month_date & "/" & year_date)    
displayDate = formatDateTime(event_date,vblongdate)    
response.write displayDate    
evuser.close
set evuser = nothing
%>
 
Im sorry, I got it slightly wrong.

The only date its pulling out is the the event with the lowest ID, so at present its the oldest date in the database, and so first in and not the last one in.

So Im guessing its not reading through the rest of the events and displaying them.

Lee
 
Sorry to keep posting, but I'm actually making some headway now.

But there still seems to be an ordering issue:


Here is all my code:

Code:
<%
'initialise objects and variables

dim strsql, conn, evuser
set conn=server.createobject("ADODB.Connection")
set evuser=server.createobject("ADODB.Recordset")
strMDBpath = Server.MapPath("users.mdb")

'direct connection
conn.open "PROVIDER=MICROSOFT.JET.OLEDB.4.0;DATA SOURCE=" & strMDBPath
%>
<%
strsql = "select date_Id, day_date, date_date, month_date, year_date, time_start "&_ 
"from Close_Date ORDER BY date_date, month_date, year_date "
'set evuser = conn.execute(strsql)
evuser.open strsql, conn
%>
<%
WHILE NOT evuser.EOF
%>
<%
date_date = evuser("date_date")   
month_date = evuser("month_date")    
year_date = evuser("year_date")
time_start = evuser("time_start")      
event_date = cdate(date_date & "/" & month_date & "/" & year_date)    
displayDate = formatDateTime(event_date,vblongdate)    
response.write (displayDate & " - " & time_start & " <br/> ")   
'evuser.close
'set evuser = nothing
%>

<%
evuser.MoveNext
Wend
%>

<%
'close resources used
evuser.close
'conn.close

'clean up
set evuser=nothing
'set conn=nothing
%>

Its probably a complete botxh job my additions, but i got it to diaplsy at least, and the ordering starts off well, then about 6/7 dates down the line, it goes wrong a bit.

Cheers
 
> then about 6/7 dates down the line, it goes wrong a bit.

Looks correct to me, unless you fixed after posting
 
looks correct to me as well...

I would personally (unless your client has requested otherwise) remove any dates that have already passed...

It's Dec 7 today and as a visitor, letting me know that on Nov 30th (a week ago) the centre was closed at 3:45 is not important to me.

The best way to acheive this is to adjust your query so only dates that have not yet occured get passed to the recordset, or you could keep your query as is and add the following if/end if clause

Code:
event_date = cdate(date_date & "/" & month_date & "/" & year_date)    
[COLOR=red]if event_date >= date() then[/color]
displayDate = formatDateTime(event_date,vblongdate)    
response.write (displayDate & " - " & time_start & " <br/> ") 
[COLOR=red]end if[/color]





--------

GOOGLE is a great resource to find answers to questions like "how do i..."


--------
 
Yes thanks guys, as I was potching with the code, it worked and its working brilliantly.

Thank you very much for all your help.

That last bit is useful too, but in this case the client is using a basic CMS, so she can add, edit and delete dates, so I will leave them to it.

Thanks again everyone

Cheers

 
I will post the code, just in case anybody needs it too.

It works perfectly.

Code:
<%
'initialise objects and variables

dim strsql, conn, evuser
set conn=server.createobject("ADODB.Connection")
set evuser=server.createobject("ADODB.Recordset")
strMDBpath = Server.MapPath("users.mdb")

'direct connection
conn.open "PROVIDER=MICROSOFT.JET.OLEDB.4.0;DATA SOURCE=" & strMDBPath
%>

<%
strsql = "select date_Id, CDate(date_date&'/'&month_date&'/'&year_date) AS EventDate, time_start "&_ 
"from Close_Date ORDER BY CDate(date_date&'/'&month_date&'/'&year_date) "
evuser.open strsql, conn
%>

<%
WHILE NOT evuser.EOF
%>

<%
time_start = evuser("time_start")
event_date = evuser("EventDate")
time_start = (time_start)    
displayDate = formatDateTime(event_date,vblongdate)    
response.write ("<div style=color:#ff000E>" & displayDate & " - " & "Closed from " & time_start & " </div> <br/> ")   
%>

<%
evuser.MoveNext
Wend
%>

<%
'close resources used
evuser.close

'clean up
set evuser=nothing
%>

Cheers
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top