1

私は現在、iOS アプリ用にすべての php サービスをベンチに置いています。そのうちの 1 つは、私の 3 つの CPU コアすべてを非常に高速に消費しているように見えます (他にはありません)。このサービスは、ユーザーが実際にいる場所に最も近い 51 個の「バブル」 (ブル) を取得します。これが私のphpです:

$sql="SELECT *, get_distance('$latitude','$longitude',latitude,longitude) AS proximite
FROM bulles INNER JOIN
(SELECT userId, userFirstName, userLastName, userName, userPictureUrl from user) AS users
ON bulles.auteur = users.userId
INNER JOIN interests
ON bulles.interet1 = interests.id
WHERE auteur = '$userID'
OR auteur
IN (
    SELECT followedId
    FROM following
    WHERE followerId = '$userID'
)
ORDER BY proximite
LIMIT 51";

そして、ここに私の保存された関数「get_distance」があります:

FUNCTION `get_distance`(lat1 DOUBLE, lng1 DOUBLE, lat2 DOUBLE, lng2 DOUBLE) RETURNS double
BEGIN
    DECLARE rlo1 DOUBLE;
    DECLARE rla1 DOUBLE;
    DECLARE rlo2 DOUBLE;
    DECLARE rla2 DOUBLE;
    DECLARE dlo DOUBLE;
    DECLARE dla DOUBLE;
    DECLARE a DOUBLE;

    SET rlo1 = RADIANS(lng1);
    SET rla1 = RADIANS(lat1);
    SET rlo2 = RADIANS(lng2);
    SET rla2 = RADIANS(lat2);
    SET dlo = (rlo2 - rlo1) / 2;
    SET dla = (rla2 - rla1) / 2;
    SET a = SIN(dla) * SIN(dla) + COS(rla1) * COS(rla2) * SIN(dlo) * SIN(dlo);
    RETURN (6378137 * 2 * ATAN2(SQRT(a), SQRT(1 - a)));
END

1 秒あたり 10 のこのサービス リクエストが CPU を飽和状態にします。私は以前に INNER JOIN ステートメントで問題を抱えていたので、そこから来ているのでしょうか? 何か案は ?

4

1 に答える 1