Saam
Saam

Reputation: 7

how display next 30 days data using php and mysql?

Have a jquery.ui.datepicker as follows:

<script type="text/javascript">
$(function() {
$("#datepicker").datepicker({
minDate: 'today',
maxDate: "+90D",
showOn: "button",
buttonImage: "images/calendar-new2.jpg",
buttonImageOnly: true,
dateFormat: "D, dd M, yy"   
});
});
</script>

And to get date datepicker included inside a form as follows:

<form method="post"><input align="center" type="hidden" id="datepicker" onChange="this.form.submit();" name="datepicker" value=""/></form>

And the following to call the data from mysql table:

<?php
$today = date('D, d M, Y');
$sql = "SELECT * FROM postings WHERE day1 = '$today' AND city = 'New York' OR day2 = '$today' AND city='New York' OR day3 = '$today' AND city='New York' OR day4 = '$today' AND city='New York' OR day5 = '$today' AND city='New York' OR day6 = '$today' AND city='New York' OR day7 = '$today' AND city='New York' OR day8 = '$today' AND city='New York' OR day9 = '$today' AND city='New York' OR day10 = '$today' AND city='New York'";
if($_POST!=""){
$mydate = mysql_real_escape_string($_POST['datepicker']);
if($mydate!=""){    
$sql = "SELECT * FROM postings WHERE day1 = '$mydate' AND city = 'New York' OR day2 = '$mydate' AND city='New York' OR day3 = '$mydate' AND city='New York' OR day4 = '$mydate' AND city='New York' OR day5 = '$mydate' AND city='New York' OR day6 = '$mydate' AND city='New York' OR day7 = '$mydate' AND city='New York' OR day8 = '$mydate' AND city='New York' OR day9 = '$mydate' AND city='New York' OR day10 = '$mydate' AND city='New York'";  
}       
}
if($mydate) {
echo "New York - $mydate";
}
else {
echo "New York - $today";
}
$num_results_per_page = 8;
$num_page_links_per_page = 5;
$pg_param1 = ""; // Ex: &q=value
$result=mysql_query($sql);
$row = mysql_fetch_array($result);
pagination($sql, $num_results_per_page, $num_page_links_per_page, $pg_param);
if($pg_error == '')
{
if(mysql_num_rows($pg_result) > 0)
{
while($data = mysql_fetch_assoc($pg_result))
{ 
echo "
-------
--------
-----
";
?>

This query will display todays data or as the data according to the date clicked by user.

Please help me for the following: 1) a next and previous button, if clicks that shows previous days data and next days data. 2) display next 7 days data.

Upvotes: 0

Views: 532

Answers (1)

Marc B
Marc B

Reputation: 360592

Your query is highly inefficient. This will work far better and is much much easier to ready:

$date = (isset($_POST['datepicker'])) ? "'" . mysql_real_escape_string($_POST['datepicker']) "'" : 'now()';

SELECT * FROM postings
WHERE (city = 'New York') and
   $date IN (day1, day2, day3, day4, day5, day6, day7, day8, day9, da10);

As for the next 7 days, just do something like:

WHERE ...
    DATE_ADD($date, INTERVAL 7 DAY) IN (....)

Upvotes: 1

Related Questions