Ответ коротким: Date возвращается GMT, если не указано иное. Вы можете установить часовой пояс, чтобы получить правильную дату. Если вы планируете использовать дату в приложении для установки чего-либо (например, localNotification time или Event), вам нужно будет сделать что-то особенное с датой, потому что если вы установите дату в iPhone, она будет установлена как GMT и будет выключена на несколько часов. (в вашем случае 4 часа). Я делаю то, что я только что описал в одном из моих приложений.
Я сделал беспорядок, пытаясь заставить это работать правильно, не отпуская часы. Это была огромная PITA, чтобы разобраться, но теперь она работает. Я скопировал, вставил и отредактировал свой код для совместного использования. Опять же, его беспорядок, но он работает! Команда pickerChanged получает информацию от UIDatePicker
. Используя приведенный ниже код. Чтобы ответить на ваш вопрос, вы можете остановиться на «destinationDate». Это вернет вам исправленное время для вашего текущего часового пояса. Я просто предоставил дополнительный взнос, когда вы пытались использовать дату на телефоне где-то.
ПРИМЕЧАНИЕ. Для быстрого примера я помещаю напоминание о событии в ту же функцию, что и datepicker, вы НЕ хотите делать что в противном случае у вас будет много напоминаний, установленных каждый раз, когда колесики прокручиваются в datepicker.
Код ниже.
- (void)pickerChanged:(id)sender
{
NSLog(@"value: %@",[sender date]);
NSDate* date= [sender date];
NSDateFormatter *formatter=[[[NSDateFormatter alloc]init]autorelease];
[formatter setDateFormat:@"MM/dd/yyyy hh:mm:ss a"];
[formatter setTimeZone:[NSTimeZone systemTimeZone]];
[formatter setTimeStyle:NSDateFormatterLongStyle];
NSString *dateSelected =[formatter stringFromDate:date];
NSString *timeZone = [dateSelected substringFromIndex:12];
NSTimeZone* destinationTimeZone = [NSTimeZone systemTimeZone];
//here we have to get the time difference between GMT and the current users Date (its in seconds)
NSInteger destinationGMTOffset = [destinationTimeZone secondsFromGMTForDate:date];
//need to reverse offset so its correct when we put it in the calendar
correctedTimeForCalendarEvent = destinationGMTOffset + (2*(-1*destinationGMTOffset));
//date to enter into calendar (we will use the correctedTimeForCalendarEvent to correct the time otherwise it will be off by a few hours )
NSDate * destinationDate = [[[NSDate alloc] initWithTimeInterval:destinationGMTOffset sinceDate:date] autorelease];
NSDate * dateForReminder = destinationDate;
// return destinationDate;
NSLog(@"value: %@ - %@",destinationDate,dateForReminder);
//DO NOT put this code in this same function this is for a quick example only on StackOverflow
//otherwise you will have reminders set everytime the users scrolled to a different time
//set event reminder
//make sure to import EventKit framework
EKEventStore *eventDB = [[[EKEventStore alloc] init]autorelease];
EKEvent *myEvent = [EKEvent eventWithEventStore:eventDB];
NSString * eventTitle = [NSString stringWithFormat:@"%@ - %@",app.dealerBusinessName,serviceOrComments.text];
myEvent.title = eventTitle;
//double check date one more time
NSLog(@"value: %@",destinationDate);
//set event time frame (1 hour) the "initWithTimeInterval" is where we account for the users timezone by adding the correctedTime from GMT to the calendar time ( so its not off by hours when entering into calendar)
myEvent.startDate = [[[NSDate alloc] initWithTimeInterval:correctedTimeForCalendarEvent sinceDate:destinationDate ]autorelease];
myEvent.endDate = [[[NSDate alloc] initWithTimeInterval:3600 sinceDate:myEvent.startDate]autorelease];
myEvent.allDay = NO;
//set event reminders 1 day and 1 hour before
myAlarmsArray = [[[NSMutableArray alloc] init] autorelease];
EKAlarm *alarm1 = [EKAlarm alarmWithRelativeOffset:-3600]; // 1 Hour
EKAlarm *alarm2 = [EKAlarm alarmWithRelativeOffset:-86400]; // 1 Day
[myAlarmsArray addObject:alarm1];
[myAlarmsArray addObject:alarm2];
myEvent.alarms = myAlarmsArray;
[myEvent setCalendar:[eventDB defaultCalendarForNewEvents]];
NSError *err;
[eventDB saveEvent:myEvent span:EKSpanThisEvent error:&err];
if (err == noErr) {
//no error, but do not show alert because we do that below.
}
}
Причина, по которой я столкнулся с этим, состояла в том, что у меня было два файла "models.py", которые содержали несколько разных полей. Я разрешил это:
У меня была такая же проблема. Это произошло после ошибки запуска Windows, похоже, из-за этого некоторые файлы были повреждены. Я снова импортировал БД из сохраненного скрипта, и он отлично работает.
У меня возникла эта проблема из-за срабатывания триггера. Работа после удаления триггера.
В моем случае параметр MySQL; lower_case_table_names
был настроен = 0
.
Он вызывает запросы, связанные с использованием верхних регистров, не будет работать.
В моем случае я выполнил эту команду, даже если таблица не была видна в PhpMyAdmin:
DROP TABLE mytable
, затем
CREATE TABLE....
Работал для меня!
Для меня это была проблема с верхним / нижним регистром. Я должен был убедиться, что имя файла таблицы, сопоставленное в запросе удаления, таблица notifications
не совпадает с Notifications
. Я исправил это, сопоставив случай с именем таблицы с запросом и сообщением MySQLWorkbench.
Что странно, так это то, что эта ошибка появилась в обработанном SQL-заявлении. Не знаю, что вызвало чувствительность этого случая. Возможно, обновление AWS RDS.
Я получил эту проблему после копирования файла таблицы mytable.idb из другого места. Чтобы устранить эту проблему, я сделал следующее:
ALTER TABLE mydatabase.mytable DISCARD TABLESPACE;
Скопировать файл mytable.idb
ALTER TABLE mydatabase.mytable IMPORT TABLESPACE;
Перезапустить MySql
Error Code: 1146. Table 'wp_commentmeta' doesn't exist
– user2473015
18 November 2015 в 07:40
Проверьте имена файлов. Возможно, вам понадобится создать новую базу данных в phpmyadmin, которая соответствует базе данных, которую вы пытаетесь импортировать.
Перезагрузка MySQL работает отлично для меня.
Имена столбцов должны быть уникальными в таблице. Вы не можете иметь два столбца с именем asd
в одной таблице.
У меня была такая же проблема и я не могу получить хороший совет для этого через Интернет, поэтому я поделился этим для вас и для всех, кто нуждается.
В моей ситуации я копирую базу данных (все файлы: frm, myd) в папку данных в папке данных MySQL (используя Wamp at home). Все было в порядке, пока я не хочу создать таблицу и имею ошибку #1146 Table '...' doesn't exist!
.
Я использую Wamp 2.1 с MySQL версии 5.5.16.
Мое решение:
ДЛЯ МЕНЯ РЕШЕНА ПРОБЛЕМА. Теперь я могу создавать таблицы снова без ошибок.
ibdata1
в случае таблиц INNODB. Если вы скопировали файлы ibdata1
и ib_logfile?
, это сработало бы.
– pprakash
10 December 2012 в 15:37
выполняется из CMD & amp; % path% = установлен в mysql / bin
mysql_upgrade -u user -ppassword
Как упоминает выше pprakash, копирование файлов table.frm И файл ibdata1 был тем, что сработало для меня. (Я бы просто прокомментировал этот комментарий, но это требование SO для 50 пунктов означает, что я должен предоставить решение, даже если это просто передел существующего ... странный.)
Вкратце:
После этого все было хорошо. (Не забудьте сделать резервную копию, если у вас есть успех!) [/ G10]
У меня была та же проблема. Я попытался создать таблицу в mysql и получил ту же ошибку. Я перезапустил сервер mysql и запустил эту команду и смог создать / перенести таблицу после повторения.
Сегодня я столкнулся с такой же проблемой. Я был в очень трудной ситуации, но какой идентификатор я создал таблицу с другим именем, например (modulemaster не создавал, затем я создавал modulemaster1), и после создания таблицы я просто делаю таблицу переименования.
Недавно у меня была такая же проблема, но на Linux Server. База данных была разбита, и я восстановил ее из резервной копии на основе простого копирования /var/lib/mysql/*
(аналоговая папка DATA mysql в wamp). После восстановления мне пришлось создать новую таблицу и получить mysql-ошибку # 1146. Я попытался перезапустить mysql, и он сказал, что это не может начаться. Я проверил журналы mysql и обнаружил, что mysql просто не имеет доступа к своим файлам DB. Я проверил информацию о владельце / var / lib / mysql / * и получил 'myuser:myuser'
(myuser is me). Но это должно быть 'mysql:adm'
(так это собственная машина для разработчиков), поэтому я сменил владельца на «mysql: adm». И после этого mysql начал нормально, и я мог создавать таблицы или делать какие-либо другие операции.
Итак, после перемещения файлов базы данных или восстановления из резервных копий проверьте доступность для mysql.
Надеюсь, что это помогает ...
Сегодня я столкнулся с той же проблемой. Я пытался создать таблицу users
, и мне было предложено ERROR 1146 (42S02): Table users doesn't exist
, что не имело никакого смысла, потому что я просто пытался создать таблицу !!
Затем я попытался удалить таблицу, набрав DROP TABLE users
, зная, что она потерпит неудачу, потому что она не существует, и я получил сообщение об ошибке Unknown table users
. После получения этой ошибки я попытался создать таблицу снова, и, как ни странно, она успешно создала таблицу!
. Моя интуиция заключается в том, что я, вероятно, создал эту таблицу раньше, и она не была полностью очищена. Явным образом сказал DROP TABLE
мне удалось как-то сбросить внутреннее состояние? Но это только моя догадка.
Короче говоря, попробуйте DROP любую таблицу, которую вы создаете, и СОЗДАЙТЕ ее снова.