首页 文章

将日期格式化为mysql格式

提问于
浏览
0

我正在处理一个有日期选择器的注册表 . 当用户选择日期时,TextView会以格式(MM-dd-YYYY)更新显示所选日期 . 当用户单击提交按钮时,它将表单数据传递到mysql数据库 . 它显然没有插入日期,因为它的格式不正确(yyyy-MM-dd) . 我尝试使用SimpleDateFormat方法,但无法使其工作 . 有人可以帮我理解如何格式化日期吗?

datedob = (TextView) findViewById(R.id.reg_dob);

String dob = datedob.getText().toString();

我的datepicker代码:

public void populateSetDate(int year, int month, int day) {
    datedob = (TextView)findViewById(R.id.reg_dob);
    datedob.setText(month + "-" + day + "-" + year);
}
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
public class SelectDateFragment extends DialogFragment implements DatePickerDialog.OnDateSetListener {
    @Override
    public Dialog onCreateDialog(Bundle savedInstanceState) {
        final Calendar calendar = Calendar.getInstance();
        int yy = calendar.get(Calendar.YEAR);
        int mm = calendar.get(Calendar.MONTH);
        int dd = calendar.get(Calendar.DAY_OF_MONTH);
        return new DatePickerDialog(getActivity(), this, yy, mm, dd);
    }

    public void onDateSet(DatePicker view, int yy, int mm, int dd) {
        populateSetDate(yy, mm+1, dd);
    }

}

1 回答

  • 1

    你需要两个 DateFormat 实例:

    • 一个解析 TextView 中的日期字符串 .

    • 一个将解析的日期格式化为所需的表示 .

    这看起来有点像这样,假设您的 TextView 包含所选日期的 "MM-dd-yyyy" 格式表示:

    String dobSource = datedob.getText().toString();
    Date dobDate = new SimpleDateFormat("MM-dd-yyyy").parse(dobSource);
    String dobTarget = new SimpleDateFormat("yyyy-MM-dd").format(dobDate);
    

    您可以通过跟踪 DateCalendar 引用来避免从 TextView 转换日期字符串,只要 onDateSet(...) 被点击就会更新 . 然后,该实例将有效地成为支持 TextView 的数据模型以及最终插入数据库的值 .

    话虽如此,我个人更喜欢以最基本的表示形式存储/保存日期:作为 long 值 . 这些值通常更容易使用(因为您避免任何解析),并且通常可以在各种平台之间更好地互换 . 最后,存储日期应该全部与实际数据有关 - 任何特定的表示/格式只会使未来的事情复杂化 .

相关问题