phpmyadmin で必要なことを正確に実行するこのクエリがあります。これは、サイトへの訪問回数を返します。例: 訪問者数: 2204
set @last_uid = 0;
set @last_tm = '00:00';
set @last_vid = 0;
SELECT MAX(
CASE WHEN @last_uid = visitorid AND cast( @last_tm as datetime) >= subtime( timestamp, '01:00' )
THEN
if( (@last_tm := timestamp ), @last_vid, @last_vid)
ELSE
if( (@last_uid := visitorid) + (@last_vid := @last_vid+1) +(@last_tm := timestamp ),@last_vid, @last_vid )
END
) as visitorCount
FROM visits v
ORDER BY timestamp DESC, visitorid
PHP からこのクエリを実行しようとすると、うまくいきません。通常の php mysql 接続と cakephp $this->Model->query(); でテストしました。成功しなければ、クエリから得られるのは「1」または true だけです。どうしたの?
$query = "set @last_uid = 0;
set @last_tm = '00:00';
set @last_vid = 0;
SELECT MAX(
CASE WHEN @last_uid = visitorid AND cast( @last_tm as datetime) >= subtime( timestamp, '01:00' )
THEN
if( (@last_tm := timestamp ), @last_vid, @last_vid)
ELSE
if( (@last_uid := visitorid) + (@last_vid := @last_vid+1) +(@last_tm := timestamp ),@last_vid, @last_vid )
END
)
FROM visits v
ORDER BY timestamp DESC, visitorid";
$con = mysql_connect("host", "user", "pass");
if (!$con) {
die(mysql_error());
}
mysql_select_db("dbname", $con);
$result = mysql_query($query);
print_r(mysql_fetch_row($result));
エラーメッセージが表示されます:
mysql_fetch_row() expects parameter 1 to be resource, boolean given