NSDate 从数据库返回错误的日期
我有一个应用程序,用户可以订购一些商品,并通过确认订单,将订单日期保存并插入到 sqlite 数据库中。
然后,稍后用户可以看到订单列表和订单日期,并且有一个选项可以让用户删除直到他们选择的任何日期的订单。
到目前为止,完全没有问题,当我选择要显示的订单时,数据库返回的日期是正确的。
当用户想要根据他们在日期选择器中选择的日期删除订单时,就会出现问题,此时我从订单对象获取的日期始终早于正确的日期,例如:
-订单日期为2011/12/20 14:24:23 +0000
-向用户显示的订单日期与上面相同
- 我想要比较日期的订单日期是 2011/12/19 14:24:23 +0000
有什么想法吗?
编辑:
#import "OrderListViewController.h"
@implementation OrderListViewController
@synthesize newOrderTabelView, transferedOrderTableView, salesOrderArr;
@synthesize newOrderTableViewController, transferedOrderViewController,salesOrder;
@synthesize newOrderTableViewHeader, transferedOrderTableViewHeader, datePicker,isPickerHidden;
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
isPickerHidden=YES;
[self initializeTableData];
}
return self;
}
- (void)dealloc
{
[newOrderTabelView release];
[transferedOrderTableView release];
[newOrderTableViewController release];
[transferedOrderViewController release];
[salesOrderArr release];
[newOrderTableViewController release];
[transferedOrderViewController release];
[salesOrder release];
[datePicker release];
[super dealloc];
}
- (void)didReceiveMemoryWarning
{
// Releases the view if it doesn't have a superview.
[super didReceiveMemoryWarning];
// Release any cached data, images, etc that aren't in use.
}
-(void)editSaleOrderForEditButton
{
YourCartViewController *yourCartViewController=[[YourCartViewController alloc] initWithNibName:@"YourCartViewController" bundle:nil];
yourCartViewController.title=@"Felton";
[self.navigationController pushViewController:yourCartViewController animated:YES];
[yourCartViewController release];
}
-(IBAction)deleteOrderButton_Tapped
{
if(isPickerHidden)
{
datePicker.hidden=NO;
isPickerHidden=NO;
}
else if(!isPickerHidden)
{
NSDate* pickerDate = [datePicker date];
datePicker.hidden=YES;
isPickerHidden=YES;
for(SalesOrder* order in salesOrderArr)
{
NSDate* orderDate = order.Date;
/*if([orderDate earlierDate:pickerDate])
{
order.isDeleted = YES;
}*/
switch([orderDate compare:pickerDate])
{
case NSOrderedAscending:
order.isDeleted = YES;
break;
case NSOrderedSame:
order.isDeleted = YES;
break;
case NSOrderedDescending:break;
}
KDSDataSalesOrder* tSaleOrder = [[KDSDataSalesOrder alloc] init];
[tSaleOrder updateSaleOrderIsDeleted:order];
[tSaleOrder release];
}
[self reloadNewOrderTable];
}
}
-(void)initializeTableData
{
KDSAppDelegate *appDelegate = [UIApplication sharedApplication].delegate;
KDSDataSalesOrder *dataSalesOrder=[[KDSDataSalesOrder alloc] init];
NSArray* tNewSalesOrderArr=[dataSalesOrder selectSalesOrdersforSalesPerson:appDelegate.loggedInSalesPerson IsUploaded:NO IsDeleted:NO];
self.salesOrderArr=tNewSalesOrderArr;
[dataSalesOrder release];
}
#pragma mark - View lifecycle
- (void)viewDidLoad
{
datePicker.hidden = YES;
[super viewDidLoad];
if(newOrderTableViewController == nil)
{
NewOrderTableViewController *tNewOrderTableViewController = [[NewOrderTableViewController alloc] init];
self.newOrderTableViewController = tNewOrderTableViewController;
self.newOrderTableViewController.orderListViewController=self;
[tNewOrderTableViewController release];
}
if(transferedOrderViewController == nil)
{
TransferedOrderTableViewController *tTransferedOrderTableViewController = [[TransferedOrderTableViewController alloc] init];
self.transferedOrderViewController = tTransferedOrderTableViewController;
[tTransferedOrderTableViewController release];
}
[newOrderTabelView setDataSource:self.newOrderTableViewController];
[newOrderTabelView setDelegate:self.newOrderTableViewController];
[transferedOrderTableView setDataSource:self.transferedOrderViewController];
[transferedOrderTableView setDelegate:self.transferedOrderViewController];
self.newOrderTableViewController.view = self.newOrderTableViewController.tableView;
self.transferedOrderViewController.view = self.transferedOrderViewController.tableView;
UIView *NewOrdeertableHeaderView = [[UIView alloc] initWithFrame:CGRectMake(newOrderTabelView.frame.origin.x, newOrderTabelView.frame.origin.y-30, self.newOrderTabelView.frame.size.width, 30)];
NewOrdeertableHeaderView.backgroundColor = [UIColor colorWithRed:0.0196 green:0.513 blue:0.949 alpha:1.0];
UILabel *NewOrderTableHeaderLabel = [[UILabel alloc] initWithFrame:CGRectMake(5, 5, self.newOrderTabelView.frame.size.width/2, 21)];
NewOrderTableHeaderLabel.text = @"New Order";
NewOrderTableHeaderLabel.backgroundColor = [UIColor clearColor];
NewOrderTableHeaderLabel.textColor = [UIColor whiteColor];
NewOrderTableHeaderLabel.textAlignment = UITextAlignmentLeft;
[NewOrdeertableHeaderView addSubview:NewOrderTableHeaderLabel];
newOrderTableViewHeader = NewOrdeertableHeaderView;
[self.view addSubview:newOrderTableViewHeader];
UIView *TransferedOrdertableHeaderView = [[UIView alloc] initWithFrame:CGRectMake(transferedOrderTableView.frame.origin.x, transferedOrderTableView.frame.origin.y-30, self.transferedOrderTableView.frame.size.width, 30)];
TransferedOrdertableHeaderView.backgroundColor = [UIColor colorWithRed:0.0196 green:0.513 blue:0.949 alpha:1.0];
UILabel *TransferedOrderTableHeaderLabel = [[UILabel alloc] initWithFrame:CGRectMake(5, 5, self.transferedOrderTableView.frame.size.width/2, 21)];
TransferedOrderTableHeaderLabel.text = @"Transfered Order";
TransferedOrderTableHeaderLabel.backgroundColor = [UIColor clearColor];
TransferedOrderTableHeaderLabel.textColor = [UIColor whiteColor];
TransferedOrderTableHeaderLabel.textAlignment = UITextAlignmentLeft;
[TransferedOrdertableHeaderView addSubview:TransferedOrderTableHeaderLabel];
transferedOrderTableViewHeader = TransferedOrdertableHeaderView;
[self.view addSubview:transferedOrderTableViewHeader];
[NewOrdeertableHeaderView release];
[NewOrderTableHeaderLabel release];
[TransferedOrdertableHeaderView release];
[TransferedOrderTableHeaderLabel release]; }
-(void)viewDidUnload
{
[super viewDidUnload];
// Release any retained subviews of the main view.
// e.g. self.myOutlet = nil;
}
-(BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
// Return YES for supported orientations
return YES;
}
-(void)reloadNewOrderTable
{
[self initializeTableData];
[self.newOrderTableViewController initializeTableData];
[newOrderTabelView reloadData];
}
@end
抱歉,如果代码混乱。问题发生在
,
NSDate* orderDate = order.Date;
其中订单来自 SalesOrder,其中包含 NSDate,此 NSDate 设置在客户确认订单的另一个位置,问题是当客户确认订单时,日期将保存在我的 SalesOrder 是正确的,但是当我尝试在上面的代码中分配它时,它会返回 1 天......可能我犯了一个错误,在这里遗漏了一些简单的事实,提前感谢您的帮助。
PS:我还在其他一些地方(订单列表)向客户显示了订单日期,并且那里的日期是正确的。
编辑:很好,Hot Licks,我得到的值是与订单相关的信息,当我分配日期NSString 使用
dateFromString
到 NSDate
:
[NSDateFormatter *formatter=[[NSDateFormatter alloc] init];
[formatter setDateFormat:@"YYYY/MM/dd hh:mm:ss"];
NSString *orderDateStr=[NSString stringWithUTF8String:(char*)sqlite3_column_text(statement, 2)];
NSDate *orderDate=[formatter dateFromString:orderDateStr];
orderDateStr
显示正确的订单日期,但 orderDate
显示前一天。我以前从未遇到过这样的事情,有什么想法吗? :)
I have an application that user can order some items and by confirming the order the date of the order is saved and inserted in a sqlite database.
Then later the user can see the order list and the order date and there's an option that user can delete the orders up to whatever date they choose.
Up to this part there's no problem at all, when I select the orders to be shown the date which was returned by database is correct.
The problem occurs when the user wants to remove orders based of the date they choose in the date picker, at this point the date I'm getting from my order object is always before the correct date, for example:
-Order date is 2011/12/20 14:24:23 +0000
-the order date shown to user is the same as above
-the order date when I want to compare dates together is 2011/12/19 14:24:23 +0000
any ideas?
edit:
#import "OrderListViewController.h"
@implementation OrderListViewController
@synthesize newOrderTabelView, transferedOrderTableView, salesOrderArr;
@synthesize newOrderTableViewController, transferedOrderViewController,salesOrder;
@synthesize newOrderTableViewHeader, transferedOrderTableViewHeader, datePicker,isPickerHidden;
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
isPickerHidden=YES;
[self initializeTableData];
}
return self;
}
- (void)dealloc
{
[newOrderTabelView release];
[transferedOrderTableView release];
[newOrderTableViewController release];
[transferedOrderViewController release];
[salesOrderArr release];
[newOrderTableViewController release];
[transferedOrderViewController release];
[salesOrder release];
[datePicker release];
[super dealloc];
}
- (void)didReceiveMemoryWarning
{
// Releases the view if it doesn't have a superview.
[super didReceiveMemoryWarning];
// Release any cached data, images, etc that aren't in use.
}
-(void)editSaleOrderForEditButton
{
YourCartViewController *yourCartViewController=[[YourCartViewController alloc] initWithNibName:@"YourCartViewController" bundle:nil];
yourCartViewController.title=@"Felton";
[self.navigationController pushViewController:yourCartViewController animated:YES];
[yourCartViewController release];
}
-(IBAction)deleteOrderButton_Tapped
{
if(isPickerHidden)
{
datePicker.hidden=NO;
isPickerHidden=NO;
}
else if(!isPickerHidden)
{
NSDate* pickerDate = [datePicker date];
datePicker.hidden=YES;
isPickerHidden=YES;
for(SalesOrder* order in salesOrderArr)
{
NSDate* orderDate = order.Date;
/*if([orderDate earlierDate:pickerDate])
{
order.isDeleted = YES;
}*/
switch([orderDate compare:pickerDate])
{
case NSOrderedAscending:
order.isDeleted = YES;
break;
case NSOrderedSame:
order.isDeleted = YES;
break;
case NSOrderedDescending:break;
}
KDSDataSalesOrder* tSaleOrder = [[KDSDataSalesOrder alloc] init];
[tSaleOrder updateSaleOrderIsDeleted:order];
[tSaleOrder release];
}
[self reloadNewOrderTable];
}
}
-(void)initializeTableData
{
KDSAppDelegate *appDelegate = [UIApplication sharedApplication].delegate;
KDSDataSalesOrder *dataSalesOrder=[[KDSDataSalesOrder alloc] init];
NSArray* tNewSalesOrderArr=[dataSalesOrder selectSalesOrdersforSalesPerson:appDelegate.loggedInSalesPerson IsUploaded:NO IsDeleted:NO];
self.salesOrderArr=tNewSalesOrderArr;
[dataSalesOrder release];
}
#pragma mark - View lifecycle
- (void)viewDidLoad
{
datePicker.hidden = YES;
[super viewDidLoad];
if(newOrderTableViewController == nil)
{
NewOrderTableViewController *tNewOrderTableViewController = [[NewOrderTableViewController alloc] init];
self.newOrderTableViewController = tNewOrderTableViewController;
self.newOrderTableViewController.orderListViewController=self;
[tNewOrderTableViewController release];
}
if(transferedOrderViewController == nil)
{
TransferedOrderTableViewController *tTransferedOrderTableViewController = [[TransferedOrderTableViewController alloc] init];
self.transferedOrderViewController = tTransferedOrderTableViewController;
[tTransferedOrderTableViewController release];
}
[newOrderTabelView setDataSource:self.newOrderTableViewController];
[newOrderTabelView setDelegate:self.newOrderTableViewController];
[transferedOrderTableView setDataSource:self.transferedOrderViewController];
[transferedOrderTableView setDelegate:self.transferedOrderViewController];
self.newOrderTableViewController.view = self.newOrderTableViewController.tableView;
self.transferedOrderViewController.view = self.transferedOrderViewController.tableView;
UIView *NewOrdeertableHeaderView = [[UIView alloc] initWithFrame:CGRectMake(newOrderTabelView.frame.origin.x, newOrderTabelView.frame.origin.y-30, self.newOrderTabelView.frame.size.width, 30)];
NewOrdeertableHeaderView.backgroundColor = [UIColor colorWithRed:0.0196 green:0.513 blue:0.949 alpha:1.0];
UILabel *NewOrderTableHeaderLabel = [[UILabel alloc] initWithFrame:CGRectMake(5, 5, self.newOrderTabelView.frame.size.width/2, 21)];
NewOrderTableHeaderLabel.text = @"New Order";
NewOrderTableHeaderLabel.backgroundColor = [UIColor clearColor];
NewOrderTableHeaderLabel.textColor = [UIColor whiteColor];
NewOrderTableHeaderLabel.textAlignment = UITextAlignmentLeft;
[NewOrdeertableHeaderView addSubview:NewOrderTableHeaderLabel];
newOrderTableViewHeader = NewOrdeertableHeaderView;
[self.view addSubview:newOrderTableViewHeader];
UIView *TransferedOrdertableHeaderView = [[UIView alloc] initWithFrame:CGRectMake(transferedOrderTableView.frame.origin.x, transferedOrderTableView.frame.origin.y-30, self.transferedOrderTableView.frame.size.width, 30)];
TransferedOrdertableHeaderView.backgroundColor = [UIColor colorWithRed:0.0196 green:0.513 blue:0.949 alpha:1.0];
UILabel *TransferedOrderTableHeaderLabel = [[UILabel alloc] initWithFrame:CGRectMake(5, 5, self.transferedOrderTableView.frame.size.width/2, 21)];
TransferedOrderTableHeaderLabel.text = @"Transfered Order";
TransferedOrderTableHeaderLabel.backgroundColor = [UIColor clearColor];
TransferedOrderTableHeaderLabel.textColor = [UIColor whiteColor];
TransferedOrderTableHeaderLabel.textAlignment = UITextAlignmentLeft;
[TransferedOrdertableHeaderView addSubview:TransferedOrderTableHeaderLabel];
transferedOrderTableViewHeader = TransferedOrdertableHeaderView;
[self.view addSubview:transferedOrderTableViewHeader];
[NewOrdeertableHeaderView release];
[NewOrderTableHeaderLabel release];
[TransferedOrdertableHeaderView release];
[TransferedOrderTableHeaderLabel release]; }
-(void)viewDidUnload
{
[super viewDidUnload];
// Release any retained subviews of the main view.
// e.g. self.myOutlet = nil;
}
-(BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
// Return YES for supported orientations
return YES;
}
-(void)reloadNewOrderTable
{
[self initializeTableData];
[self.newOrderTableViewController initializeTableData];
[newOrderTabelView reloadData];
}
@end
sorry if the code is messed up. the problem occurs at
NSDate* orderDate = order.Date;
where order comes from SalesOrder which has an NSDate in it, this NSDate is set in another place where the customer confirms the order, the thing is when the customer confirms the order, the date that will be saved in my SalesOrder is correct, but when I'm trying to assign it in the above code, it goes 1 day back... probably I'm making a mistake and missing some simple fact here, thanks in advance for the help.
P.S: I'm also showing the oder date to customer in some other places (list of orders) and the date in there is correct.
Edit: Nice catch Hot Licks, the values I'm getting there are information related to the order, it appears the problem is in below code when I'm assigning the date NSString
to NSDate
using dateFromString
:
[NSDateFormatter *formatter=[[NSDateFormatter alloc] init];
[formatter setDateFormat:@"YYYY/MM/dd hh:mm:ss"];
NSString *orderDateStr=[NSString stringWithUTF8String:(char*)sqlite3_column_text(statement, 2)];
NSDate *orderDate=[formatter dateFromString:orderDateStr];
the orderDateStr
shows the correct date of order, but orderDate
shows the day before. I've never encounter such a thing before, any idea ? :)
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我想知道你的日期格式是否覆盖了末尾的+0000。尝试类似 [formatter setTimeZone:[NSTimeZone timeZoneForSecondsFromGMT:0]];在解析之前。
I wonder if your date format covers the +0000 at the end.Try something like [formatter setTimeZone:[NSTimeZone timeZoneForSecondsFromGMT:0]]; before parsing.