問題が発生しているのは、mysql_queryからフォーマットされたものに合うようにphpの日付をフォーマットすることだと思います
これが私が思いついたものです。
これを処理するための簡単なコードを作成しました。
手順は、mysqlのCURDATE()関数を使用してmysqlから今日の日付を取得し、それをフォーマットして、テーブルの既存の列と一致させることです。
MYSQLデータベース
-- phpMyAdmin SQL Dump
-- version 3.4.5
-- http://www.phpmyadmin.net
--
-- Host: localhost
-- Generation Time: Oct 04, 2012 at 01:44 PM
-- Server version: 5.5.16
-- PHP Version: 5.3.8
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";
--
-- Database: `my_db`
--
-- --------------------------------------------------------
--
-- Table structure for table `datetable`
--
CREATE TABLE IF NOT EXISTS `datetable` (
`dateid` int(2) NOT NULL AUTO_INCREMENT,
`datestuff` date NOT NULL,
PRIMARY KEY (`dateid`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;
--
-- Dumping data for table `datetable`
--
INSERT INTO `datetable` (`dateid`, `datestuff`) VALUES
(1, '2012-10-02'),
(2, '2012-10-04');
PHPコード(ファイル)
<?php
//Connect to your host
$con = mysql_connect("localhost","admin","admin");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
//select your database
mysql_select_db("my_db", $con);
//getting today's date and formating it, output is like this (4-10-2012)
$today = date('j-m-Y');
//query your table, also date has been formated like this (4-10-2012)
$result = mysql_query("SELECT DATE_FORMAT( CURDATE( ) , '%e-%m-%Y' ) AS today, DATE_FORMAT( datestuff, '%e-%m-%Y' ) AS datestuff FROM datetable WHERE CURDATE( ) = datestuff");
//get the resultset
while($row = mysql_fetch_array($result))
{
echo "date in table: ".$row['datestuff']. "---- today's date: ". $row['datestuff'];
echo "<br />";
}
?>
それがあなたのためにうまくいったかどうか私に知らせてみてください....