java 如何判断从页面输入的时间段内有没有某个时间

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 如何判断从页面输入的时间段内有没有某个时间相关的知识,希望对你有一定的参考价值。

如我从页面输入两个时间2009-10-10 和2009-12-12 ,判断数据库中是否存在在这段时间内的具体日期
火急!!
谢谢!

select count(*) from tableName where Times between '2009-10-10' and '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 如何判断从页面输入的时间段内有没有某个时间的主要内容,如果未能解决你的问题,请参考以下文章

java中怎么判断字符串里有没有指定的字符存在?

java 判断一个数值是不是在一个数值区间内

用java编写实现从键盘输入一个字符串,判断其是不是为浮点数?

SQL中where条件如何判断某个字段有没有

如何从jQuery中的输入字段中删除焦点?

ASP.NET如何判断某个页面已经在浏览器打开