NSDate的处理:前一天、后一天等关于时区偏移的处理以及在数据库中的使用

2024-08-22 18:38

本文主要是介绍NSDate的处理:前一天、后一天等关于时区偏移的处理以及在数据库中的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

看来很多网上关于日期的处理,今天、昨天、前天、后天、一周等,满心欢喜的拿着去验证结果总是不尽如人意,看别别人的代码看的脑涨,自己就写一个简单的,自己来用,以后用其他的方法,我会在完善,再次记录,以方便以后查阅

                                                                                                                                    --宋飞祥    2014.7.19

直接上代码,很容易理解:

#import <Foundation/Foundation.h>@interface MyCutomNSDateDeal : NSObject+(NSInteger)timeZoneOffset;
+(NSInteger)preDayOfTheDate_start:(NSDate *)date;
+(NSInteger)preDayOfTheDate_end:(NSDate *)date;
+(NSInteger)nextDayOfTheDate_start:(NSDate *)date;
+(NSInteger)nextDayOfTheDate_end:(NSDate *)date;@end

#import "MyCutomNSDateDeal.h"@implementation MyCutomNSDateDeal+(NSInteger)timeZoneOffset
{NSDate *date = [NSDate date];NSTimeZone *zone = [NSTimeZone systemTimeZone];NSInteger offset = [zone secondsFromGMTForDate:date];return offset;
}
/***  根据给出的日期,返回该日期的前一天的起点(相对于日期起点,seconds的计数)**  @param date 日期**  @return 返回的是seconds计数,相对于日历系统起始至该日期前一天的起点(就是0点)*/
+(NSInteger)preDayOfTheDate_start:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]-24];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];
}/***  根据给出的日期,返回该日期的前一天的终点(也就是给出日期的起点)**  @param date 给定的日期**  @return 返回的是seconds计数*/
+(NSInteger)preDayOfTheDate_end:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];
}+(NSInteger)nextDayOfTheDate_start:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]+24];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];}+(NSInteger)nextDayOfTheDate_end:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]+ 2*24];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];}//+(NSInteger)preWeekOfTheDate_@end


使用如下:

这里我取得date 为当天的,用户可以换成自己想要的相对日期即可!!

 NSDate *today = [NSDate date];NSLog(@"today ::::: %@",today);NSInteger today_int = [MyCutomNSDateDeal preDayOfTheDate_start:today];NSDate *per_start = [NSDate dateWithTimeIntervalSince1970:today_int];NSLog(@"per_start _:_ %@",per_start);NSDate *per_end = [NSDate dateWithTimeIntervalSince1970:[MyCutomNSDateDeal preDayOfTheDate_end:today]];NSLog(@"per_end -:- %@",per_end);NSDate *next_start = [NSDate dateWithTimeIntervalSince1970:[MyCutomNSDateDeal nextDayOfTheDate_start:today]];NSDate *next_end = [NSDate dateWithTimeIntervalSince1970:[MyCutomNSDateDeal nextDayOfTheDate_end:today]];NSLog(@"next_start === %@",next_start);NSLog(@"next_end === %@",next_end);
打印结果如下:

2014-07-19 <span style="color:#FF0000;">15:26:30.565 </span>FMDBSortByDateDemo[4423:60b] today ::::: 2014-07-19 <span style="color:#FF0000;">07:26:30</span> +0000
2014-07-19 15:26:30.566 FMDBSortByDateDemo[4423:60b] per_start _:_ 2014-07-18 00:00:00 +0000
2014-07-19 15:26:30.566 FMDBSortByDateDemo[4423:60b] per_end -:- 2014-07-19 00:00:00 +0000
2014-07-19 15:26:30.566 FMDBSortByDateDemo[4423:60b] next_start === 2014-07-20 00:00:00 +0000
2014-07-19 15:26:30.567 FMDBSortByDateDemo[4423:60b] next_end === 2014-07-21 00:00:00 +0000
第一行打印可以看出,我们打印的时间理我现在真正需要的时间差8个小时,这就是时区的偏移,加上8个小时就对了,下面的打印在我定义的头文件中,已经把相对偏加上了!


这里我想说的是:我项目中用到要存数据和date,而数据库(FMDB)是不支持date格式的,我采取的是把相对日历起点的seconds(秒)存起来,通过比对秒数来取想要的数据!

如果大家有好的方法,可以交流!!

下面是我的数据库取值过程:

 NSInteger inter = [MyCutomNSDateDeal preDayOfTheDate_end:today];NSString *sql = [NSString stringWithFormat:@"SELECT * FROM Temperature WHERE Date > %i ",inter];// NSString *sql = [NSString stringWithFormat:@"SELECT * FROM Temperature WHERE Date between %li and %li",from,to];if ([db open]) {FMResultSet *rs = [db executeQuery:sql];while ([rs next]) {NSString *name = [rs stringForColumn:@"Name"];NSInteger time = [rs intForColumn:@"Date"];NSDate *date = [NSDate dateWithTimeIntervalSince1970:time];float temp = [rs doubleForColumn:@"Temperature"];NSString *event = [rs stringForColumn:@"Event"];NSLog(@"Name:%@,Date:%@,Temperature:%f,Event:%@",name,date,temp,event);}}

两个sql语句都验证了,是正确的,有一点我要说的是,我们在处理取出的数据时,加上了偏移量,所以我们存取数据时,也要加上偏移量,应该如下:

-(void)temperatureAndDateUpdate:(float)value
{NSDate *date = [NSDate date];NSInteger time = [date timeIntervalSince1970];time = time + [MyCutomNSDateDeal timeZoneOffset]; //加上时区偏移量NSDate *date1 = [NSDate dateWithTimeIntervalSince1970:time];NSLog(@"temperature update    date1 === %@",date1);if ([db open]) {[db executeUpdate:@"INSERT INTO Temperature(Name,Date,Temperature,Event) VALUES (?,?,?,?)",@"SFX",[NSNumber numberWithInteger:time],[NSNumber numberWithFloat:value],@"吃药"];NSLog(@"success!!");}else{NSLog(@"error:   %@   %@",[db lastError],[db lastErrorMessage]);}[db close];
}


这篇关于NSDate的处理:前一天、后一天等关于时区偏移的处理以及在数据库中的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097079

相关文章

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND