• SqlServer根据生日计算年龄,精确到年(岁)月日小时分秒


    根据生日获取年龄不仅仅是“多少岁”,还可能涉及到年龄不到“1岁”、不到“1月”、不到“1天”、不到“1小时”、不到“1分钟”的情况,整理如下脚本,做以笔记:

    DECLARE @BirthDate DATETIME
    DECLARE @CurrentDate DATETIME
    SET @BirthDate = '2014-04-29 12:59:00.000'
    SET @CurrentDate = '2014-04-29 13:10:23.000'
    
    DECLARE @DiffInYears INT
    DECLARE @DiffInMonths INT
    DECLARE @DiffInDays INT
    DECLARE @DiffInHours INT
    DECLARE @DiffInMinutes INT
    DECLARE @DiffInSeconds INT
    DECLARE @TotalSeconds BIGINT
    
    -- Determine Year, Month, and Day differences
    SET @DiffInYears = DATEDIFF(year, @BirthDate, @CurrentDate)
    IF @DiffInYears > 0
        SET @BirthDate = DATEADD(year, @DiffInYears, @BirthDate)
    IF @BirthDate > @CurrentDate
    BEGIN
        -- Adjust for pushing @BirthDate into future
        SET @DiffInYears = @DiffInYears - 1
        SET @BirthDate = DATEADD(year, -1, @BirthDate)
    END
    
    SET @DiffInMonths = DATEDIFF(month, @BirthDate, @CurrentDate)
    IF @DiffInMonths > 0
        SET @BirthDate = DATEADD(month, @DiffInMonths, @BirthDate)
    IF @BirthDate > @CurrentDate
    BEGIN
        -- Adjust for pushing @BirthDate into future
        SET @DiffInMonths = @DiffInMonths - 1
        SET @BirthDate = DATEADD(month, -1, @BirthDate)
    END
    
    SET @DiffInDays = DATEDIFF(day, @BirthDate, @CurrentDate)
    IF @DiffInDays > 0
        SET @BirthDate = DATEADD(day, @DiffInDays, @BirthDate)
    IF @BirthDate > @CurrentDate
    BEGIN
        -- Adjust for pushing @BirthDate into future
        SET @DiffInDays = @DiffInDays - 1
        SET @BirthDate = DATEADD(day, -1, @BirthDate)
    END
    
    -- Get number of seconds difference for Hour, Minute, Second differences
    SET @TotalSeconds = DATEDIFF(second, @BirthDate, @CurrentDate)
    
    -- Determine Seconds, Minutes, Hours differences
    SET @DiffInSeconds = @TotalSeconds % 60
    SET @TotalSeconds = @TotalSeconds / 60
    
    SET @DiffInMinutes = @TotalSeconds % 60
    SET @TotalSeconds = @TotalSeconds / 60
    
    SET @DiffInHours = @TotalSeconds
    
    -- Display results
     SELECT @DiffInYears AS YearsDiff,
            @DiffInMonths AS MonthsDiff,
            @DiffInDays AS DaysDiff,
            @DiffInHours AS HoursDiff,
            @DiffInMinutes AS MinutesDiff,
            @DiffInSeconds AS SecondsDiff 
  • 相关阅读:
    Android滑动菜单框架完全解析,教你如何一分钟实现滑动菜单特效
    Android滑动菜单特效实现,仿人人客户端侧滑效果,史上最简单的侧滑实现
    Android桌面悬浮窗效果实现,仿360手机卫士悬浮窗效果
    各产品编译及串口烧录
    C 语言代码规范
    烧录
    共享目录
    openwrt Makefile
    netfilter 参考pywj的《netfilter + nf_conntrack + iptables》
    iptables问题
  • 原文地址:https://www.cnblogs.com/seanyan/p/14293829.html
Copyright © 2020-2023  润新知