Как преобразовать значение метки времени datetime в mysql в Android studio

#java #android #mysql

#java #Android #mysql

Вопрос:

Я пытаюсь преобразовать / получить значение DatePickerDialog EditText «etDate» в базу данных mysql. DatePickerDialog работает нормально (я могу открыть его и выбрать дату и отобразить ее в EditText).

И я объявляю это, как показано ниже (временная метка — java.sql.Timestamp 🙂

 final Timestamp datetime = Timestamp.valueOf(etDate.getText().toString());
  

Приведенный выше код я добавляю его в bRegister.setOnClickListener

код не показывает ошибок, и приложения могут запускаться, но когда я нажимаю на bRegister.setOnClickListener, он показывает ошибку, как показано ниже.

 E/AndroidRuntime: FATAL EXCEPTION: main
                  Process: my.com.rozaimi.datetime, PID: 15786
                  java.lang.IllegalArgumentException: Timestamp format must be yyyy-MM-dd HH:mm:ss.fffffffff; was '2016-10-6'
                      at java.sql.Timestamp.badTimestampString(Timestamp.java:507)
                      at java.sql.Timestamp.valueOf(Timestamp.java:414)
                      at my.com.rozaimi.datetime.MainActivity$2.onClick(MainActivity.java:62)
                      at android.view.View.performClick(View.java:4438)
                      at android.view.View$PerformClick.run(View.java:18422)
                      at android.os.Handler.handleCallback(Handler.java:733)
                      at android.os.Handler.dispatchMessage(Handler.java:95)
                      at android.os.Looper.loop(Looper.java:136)
                      at android.app.ActivityThread.main(ActivityThread.java:5017)
                      at java.lang.reflect.Method.invokeNative(Native Method)
                      at java.lang.reflect.Method.invoke(Method.java:515)
                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                      at dalvik.system.NativeStart.main(Native Method)
Application terminated.
  

Ответ №1:

Вы пытаетесь проанализировать строку даты, когда ожидается временная метка, и вывод ошибки довольно ясен по этому поводу. Одним из обходных путей было бы создать java.util.Date , используя вашу строку даты, затем инициализировать java.sql.Timestamp объект, используя миллисекунды с момента начала эпохи:

 String dateString = etDate.getText().toString();
DateFormat df = new SimpleDateFormat("yyyy-MM-dd"); 
java.util.Date date;
try {
    date = df.parse(dateString);
    Timestamp datetime = new Timestamp(date.getTime());
} catch (ParseException e) {
    e.printStackTrace();
}
  

Строка

 Timestamp datetime = new Timestamp(date.getTime());
  

использует конструктор java.sql.Timestamp для создания временной метки с использованием миллисекунд с момента начала эпохи.

Комментарии:

1. Привет. спасибо за быстрый ответ. ваш приведенный выше код, мне нужно добавить его в прослушиватель bRegister или в метод onCreate?

2. Дата в Android имеет два типа: Date(java.util) и Date (java.sql), какой из них? еще раз спасибо 🙂

3. Я не знаю, где именно вам нужно это добавить, но это должно заменить вашу текущую однострочную попытку создания с java.sql.Timestamp использованием строки даты.