我正在为我的网站创建一个同级页面,并且我正在尝试获取一个可以从users表中获取用户的查询,该表的结构为id, name, gender, dob。查询应该获取相对于登录用户的出生日期的用户,即,用户的道布比登录用户的道布少2岁或多3岁。表中的道布的结构类似于1993-03-23。我需要查询的帮助,这样它才能满足我的要求。这是一个基本的示例查询。
$users = $db->query(
'SELECT users.name FROM users WHERE users.id=:id',
array(':id'=>$userid)
);发布于 2021-08-25 08:25:30
如果您知道登录用户道布可以使用下一种方法:
<?php
$logged_user_dob = '1993-01-01';
$query = "SELECT *
FROM tbl
WHERE dob BETWEEN DATE_SUB(:logged_user_dob, INTERVAL 2 YEAR) AND DATE_ADD(:logged_user_dob, INTERVAL 3 YEAR)";
$stmt = $pdo->prepare($query);
$stmt->execute([':logged_user_dob'=>'1993-01-01']);
$res = $stmt->fetchAll(PDO::FETCH_ASSOC);
var_export($res);如果您只记录了用户id -请使用next查询:
<?php
$query = "SELECT tbl.*
FROM tbl
JOIN tbl AS tmp ON
tbl.dob BETWEEN DATE_SUB(tmp.dob, INTERVAL 2 YEAR) AND DATE_ADD(tmp.dob, INTERVAL 3 YEAR)
AND tmp.id = :id
WHERE tbl.id <> :id";
$stmt = $pdo->prepare($query);
$stmt->execute([':id'=>2]);
$res = $stmt->fetchAll(PDO::FETCH_ASSOC);
var_export($res);https://stackoverflow.com/questions/68919110
复制相似问题