How to convert a user entered date (dd/mm/yy) into a format for a mysql database (yyyy/mm/dd)?

Posted on 2006-07-12
Medium Priority
Last Modified: 2012-08-13
An HTML form requires the user to enter a date. As this is uk, I would like the user to be able to enter in a format - dd/mm/yy. I am not familiar enough with the java Date classes to be able to convert this into a format suitable to be entered into a mysql database. Do I need to parse the String and create a Date object first before using SimpleDateFormat?  Would appreciate some assistance. Thank you.
Question by:SimonAllen
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
LVL 35

Expert Comment

ID: 17089554
Use the SimpleDateFormat:

SimpleDateFormat sdf = new SimpelDateFormat("YYYY/MM/dd");
Date d = sdf.parse(<date from form>);
LVL 35

Expert Comment

ID: 17089558

> SimpleDateFormat sdf = new SimpelDateFormat("YYYY/MM/dd");

should be

SimpleDateFormat sdf = new SimpelDateFormat("yyyy/MM/dd");
LVL 35

Expert Comment

ID: 17089562
> Do I need to parse the String and create a Date object first before using SimpleDateFormat?

No, just get the String from the HTML form and parse it liek I did in my example. Then you can create a date object to insert into the database with the new format (yyyy/mm/dd)
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 10

Expert Comment

ID: 17089565
SimpleDateFormat sdf = new SimpelDateFormat("dd/mm/yy");
java.util.Date d = sdf.parse(<date from form>);

to insert this date into your database,

java.sql.Date date = new java.sql.Date ( d.getTime () ) ;

LVL 10

Accepted Solution

mukundha_expert earned 180 total points
ID: 17089576
actually it should be ,

SimpleDateFormat sdf = new SimpelDateFormat("dd/MM/yy");
LVL 35

Assisted Solution

girionis earned 320 total points
ID: 17089587
> SimpelDateFormat("dd/mm/yy");

Bah... you are right, this is the format in the form... I thought the other way round.
LVL 35

Expert Comment

ID: 17089679
> As this is uk, I would like the user to be able to enter in a format - dd/mm/yy

If you are talking about entering the date in the proper format in the form, then you should use JavaScript to do it: http://www.experts-exchange.com/Web/Web_Languages/JavaScript/Q_21449630.html
LVL 86

Expert Comment

ID: 17090338
You would be better off not allowing the user to type anything at all, or you may get errors

Author Comment

ID: 17091801
Thank you guys - your solution works of course. By way of explanation (for CEHJ) the application is designed to allow pilots to log their flying hours so the date entered by the user will not necessarily be the current date. Also, it did occur to me that I do not have to use a Date object at all. I could transform the string from the form(dd/mm/yy) to another string(yyyy/mm/dd) using java's substring method. This could be entered into the mysql database as is. Not quite sure which method is best yet. Many thanks anyway, Simon

Featured Post

Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Are you developing a Java application and want to create Excel Spreadsheets? You have come to the right place, this article will describe how you can create Excel Spreadsheets from a Java Application. For the purposes of this article, I will be u…
Introduction This article is the first of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article explains our test automation goals. Then rationale is given for the tools we use to a…
Viewers learn about the scanner class in this video and are introduced to receiving user input for their programs. Additionally, objects, conditional statements, and loops are used to help reinforce the concepts. Introduce Scanner class: Importing…
This tutorial will introduce the viewer to VisualVM for the Java platform application. This video explains an example program and covers the Overview, Monitor, and Heap Dump tabs.
Suggested Courses

649 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question