0

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

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

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

我的日期选择器代码:

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);
    }

}
4

1 回答 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);

TextView您可以通过跟踪每次命中时更新的DateCalendar引用来潜在地避免从 转换日期字符串。onDateSet(...)然后,该实例将有效地成为支持 的数据模型TextView以及最终插入数据库的值。

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

于 2013-09-30T03:41:07.643 回答