java 如何判断从页面输入的时间段内有没有某个时间
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 如何判断从页面输入的时间段内有没有某个时间相关的知识,希望对你有一定的参考价值。
如我从页面输入两个时间2009-10-10 和2009-12-12 ,判断数据库中是否存在在这段时间内的具体日期
火急!!
谢谢!
返回数大于0则是存在该段时间的数据。 参考技术A 我用的数据库是ORACLE
SimpleDateFormat formater = new SimpleDateFormat("yyyy-MM-dd");
String sql = "select count(*) from table a where 1=1 ";
String startDate="2009-10-10";
String endDate="2009-12-12";
if (startDate != null)
sql += " and a.create_date >= to_date('" + formater.format(startDate)
+ " 00:00:00','yyyy-mm-dd hh24:mi:ss')";
if (endDate != null)
sql += " and a.create_date <= to_date('" + formater.format(endDate)
+ " 23:59:59','yyyy-mm-dd hh24:mi:ss') ";
参考技术B 直接一个sql语句让数据库字段大于最小的日期,小于最大的日期不就好了么?!
不过不同的数据库写法是不一样的
ios中利用NSDateComponentsNSDateNSCalendar判断当前时间是否在一天的某个时间段内
应用中设置一般会存在这样的设置,如夜间勿扰模式,从8:00-23:00,此时如何判断当前时间是否在该时间段内。难点主要在于如何用NSDate生成一个8:00的时间和23:00的时间,然后用当前的时间跟这俩时间作对比就好了。
下面提供两条思路:
法1.用NSDate生成当前时间,然后转为字符串,从字符串中取出当前的年、月、日,然后再拼上时、分、秒,然后再将拼接后的字符串转为 NSDate,最后用当前的时间跟自己生成的俩NSDate的时间点比较。(该方法比较笨,也不难,但看起来有点太菜了,看上去不怎么规范)
法2.用NSDateComponents、NSCalendar确定俩固定的NSDate格式的时间,然后再进行比较(此方法比较装逼,其实跟拼字符串的方法复杂度差不了多少,但看起来比较规范,像是大神写的)。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
/** * @brief 判断当前时间是否在fromHour和toHour之间。如,fromHour=8,toHour=23时,即为判断当前时间是否在8:00-23:00之间 */ - (BOOL)isBetweenFromHour:(NSInteger)fromHour toHour:(NSInteger)toHour { NSDate *date8 = [self getCustomDateWithHour: 8 ]; NSDate *date23 = [self getCustomDateWithHour: 23 ]; NSDate *currentDate = [NSDate date]; if ([currentDate compare:date8]==NSOrderedDescending && [currentDate compare:date23]==NSOrderedAscending) { NSLog(@ "该时间在 %d:00-%d:00 之间!" , fromHour, toHour); return YES; } return NO; } /** * @brief 生成当天的某个点(返回的是伦敦时间,可直接与当前时间[NSDate date]比较) * @param hour 如hour为“8”,就是上午8:00(本地时间) */ - (NSDate *)getCustomDateWithHour:(NSInteger)hour { //获取当前时间 NSDate *currentDate = [NSDate date]; NSCalendar *currentCalendar = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar]; NSDateComponents *currentComps = [[NSDateComponents alloc] init]; NSInteger unitFlags = NSYearCalendarUnit | NSMonthCalendarUnit | NSDayCalendarUnit | NSWeekdayCalendarUnit | NSHourCalendarUnit | NSMinuteCalendarUnit | NSSecondCalendarUnit; currentComps = [currentCalendar components:unitFlags fromDate:currentDate]; //设置当天的某个点 NSDateComponents *resultComps = [[NSDateComponents alloc] init]; [resultComps setYear:[currentComps year]]; [resultComps setMonth:[currentComps month]]; [resultComps setDay:[currentComps day]]; [resultComps setHour:hour]; NSCalendar *resultCalendar = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar]; return [resultCalendar dateFromComponents:resultComps]; } |
以上是关于java 如何判断从页面输入的时间段内有没有某个时间的主要内容,如果未能解决你的问题,请参考以下文章