首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从出生日期开始获取日期范围

从出生日期开始获取日期范围
EN

Stack Overflow用户
提问于 2021-08-25 08:06:32
回答 1查看 41关注 0票数 0

我正在为我的网站创建一个同级页面,并且我正在尝试获取一个可以从users表中获取用户的查询,该表的结构为id, name, gender, dob。查询应该获取相对于登录用户的出生日期的用户,即,用户的道布比登录用户的道布少2岁或多3岁。表中的道布的结构类似于1993-03-23。我需要查询的帮助,这样它才能满足我的要求。这是一个基本的示例查询。

代码语言:javascript
复制
$users = $db->query(
    'SELECT users.name FROM users WHERE users.id=:id',
    array(':id'=>$userid)
);
EN

Stack Overflow用户

回答已采纳

发布于 2021-08-25 08:25:30

如果您知道登录用户道布可以使用下一种方法:

代码语言:javascript
复制
<?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);

Share PHP code online

如果您只记录了用户id -请使用next查询:

代码语言:javascript
复制
<?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);

Run & test PHP code online

票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68919110

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档