1

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
4

1 に答える 1

1

複数のステートメントを実行しているためかどうかはわかりませんが、1つにまとめてみてください。

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,
        (SELECT @last_uid := 0, @last_tm := '00:00', @last_vid := 0;) x
ORDER   BY timestamp DESC, visitorid
于 2013-10-12T02:30:38.203 に答える