SQL 中在表内查询近 3 天内生日的学生信息(注意闰年的情况)

下图是测试数据截图




解决方案


declare @nowdate datetime
set @nowdate=convert(datetime,GETDATE())
 select 考生号,姓名,convert(varchar(10),生日,120)birth from 
	(select *, (case when not(year(@nowdate)%4=0 and year(@nowdate)%100<>0 or year(@nowdate)%400=0)
	-- 判断是否为闰年
	and month(生日)=2 and day(生日)=29
	-- 判断考生生日是否为 2 月 29 日 
	t
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个示例程序,用于计算给定日期在本年的天数。请注意,此程序假定输入的日期是有效的,并且年份为四位数。 ```c #include <stdio.h> struct date { int year; int month; int day; }; int is_leap_year(int year) { return (year % 4 == 0 && year % 100 != 0) || year % 400 == 0; } int get_day_of_year(struct date d) { int days_in_month[] = {31, 28 + is_leap_year(d.year), 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; int day_of_year = 0; for (int i = 0; i < d.month - 1; i++) { day_of_year += days_in_month[i]; } day_of_year += d.day; return day_of_year; } int main() { struct date d = {2022, 2, 1}; int day_of_year = get_day_of_year(d); printf("%d-%d-%d is day %d of the year %d\n", d.year, d.month, d.day, day_of_year, d.year); return 0; } ``` 在上面的示例程序,我们首先定义了一个 `date` 结构体,用于表示日期。然后,我们使用 `is_leap_year()` 函数来判断给定年份是否为闰年,如果是,则返回 1,否则返回 0。接下来,我们使用 `get_day_of_year()` 函数来计算给定日期在本年的天数。在这个函数,我们首先定义了一个数组 `days_in_month`,其包含了每个月的天数,注意在第二个元素加上了 `is_leap_year(d.year)`,用于处理闰年情况。然后,我们使用一个循环来累加前面月份的天数,最后再加上当前月份的天数,即为本年的天数。最后,在 `main()` 函数,我们创建了一个日期变量 `d`,并使用 `get_day_of_year()` 函数来计算该日期在本年的天数,然后输出结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值